Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Wrap lines in log messages with line feeds #2967

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

cdjackson
Copy link
Contributor

This wraps log messages where the message has a line feed sequence. The main case for this is exception / stack traces.

image

Closes #2961

Copy link

relativeci bot commented Jan 2, 2025

#2630 Bundle Size — 10.97MiB (~+0.01%).

b451e1a(current) vs 095584a main#2628(baseline)

Warning

Bundle contains 2 duplicate packages – View duplicate packages

Bundle metrics  Change 1 change
                 Current
#2630
     Baseline
#2628
No change  Initial JS 1.9MiB 1.9MiB
No change  Initial CSS 577.21KiB 577.21KiB
Change  Cache Invalidation 17.4% 22.71%
No change  Chunks 227 227
No change  Assets 250 250
No change  Modules 2949 2949
No change  Duplicate Modules 154 154
No change  Duplicate Code 1.78% 1.78%
No change  Packages 98 98
No change  Duplicate Packages 2 2
Bundle size by type  Change 2 changes Regression 2 regressions
                 Current
#2630
     Baseline
#2628
Regression  JS 9.18MiB (~+0.01%) 9.18MiB
Regression  CSS 866.31KiB (~+0.01%) 866.3KiB
No change  Fonts 526.1KiB 526.1KiB
No change  Media 295.6KiB 295.6KiB
No change  IMG 140.74KiB 140.74KiB
No change  HTML 1.38KiB 1.38KiB
No change  Other 871B 871B

Bundle analysis reportBranch cdjackson:logviewer-supportlinef...Project dashboard


Generated by RelativeCIDocumentationReport issue

@wborn
Copy link
Member

wborn commented Jan 2, 2025

Hello @openhab/webui-maintainers. Can you make the GHA CI build required instead of the Jenkins CI build? I disabled the PR builds in Jenkins for repos that already have a GHA CI build as a first step to migrate everything to GHA.

@@ -486,7 +485,7 @@ export default {
milliseconds: ms,
level: logEntry.level.toUpperCase(),
loggerName: logEntry.loggerName,
message: logEntry.message
message: logEntry.message.replace(/\n/g, '<br>')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would add some indentation here as well, for example 2 spaces.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've not looked at a "real" stack trace - doesn't it have tabs (or whitespace of some description) after the break. In theory it should render with some indentation.

While I understand your thinking, I'm a little hesitant to add "random" indentation. In principal, this isn't stack trace specific - it should (IMHO) faithfully represent whatever was received in the logger message - so if the message has indentation, then we should also have some, but if not, we shouldn't add any extra (IMHO).

WDYT?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've not looked at a "real" stack trace - doesn't it have tabs (or whitespace of some description) after the break. In theory it should render with some indentation.

I was only looking at your screenshot above and wondered where the indentation was.
I think normally the exception message itself has intendation.
Will check this.

@florian-h05
Copy link
Contributor

@wborn Done. We have to check if the requirement still works when upgrading the action and its name changes.

@ghys
Copy link
Member

ghys commented Jan 2, 2025

I think this will break the "virtual table" from #2905 where every row is expected to be exactly 31 pixels high.

Maybe another way to deal with these multi-line messages is to only display the first line and let the user know there's more. They can then click on the row (or an icon) to reveal the entire message in a popup.

@cdjackson
Copy link
Contributor Author

Interestingly I don't see any issues with this - what do you expect to happen @ghys ? Is it during the removal that lines might get out of sync or something?

@cdjackson
Copy link
Contributor Author

Looking at the code, it seems that the index of the rows might be wrong - but does that really matter? I mean, the user will scroll to the lines they want to see, so this is kind of self compensating - right?

@cdjackson
Copy link
Contributor Author

So what I can notice is when a stack trace comes in, the table only scrolls up 1 line rather than 4 (or whatever). This seems to trigger the detection that we're not at the bottom of the list, and the user needs to scroll down. After this, it works fine.

Personally, I think this is ok. I don't think there should be loads of multi-line messages - although if there were it might get a bit messy.

I'm also ok with @ghys suggestion to only show the first line and then have a popup if that's preferred.

@ghys
Copy link
Member

ghys commented Jan 3, 2025

Interestingly I don't see any issues with this - what do you expect to happen @ghys ? Is it during the removal that lines might get out of sync or something?

What I feared is that the scrolling would act up - I didn't test it - but glad to hear it's not so bad.

It still would perhaps have inconsistent scrollbar behaviour because with a fixed row height, a table with x rows is a predictable 31 * x pixels high and doesn't depend on the height of individual entries, so you can easily calculate the height of the padding empty spaces on either side to maintain that height and the illusion of scrolling through a table with all entries rendered.

@florian-h05 florian-h05 added enhancement New feature or request main ui Main UI labels Jan 7, 2025
@florian-h05
Copy link
Contributor

Using the following UI rule and watching the logs, rendering sometimes flickers to a black or white screen:

configuration: {}
triggers:
  - id: "1"
    configuration:
      cronExpression: "* * * * * ? *"
    type: timer.GenericCronTrigger
conditions: []
actions:
  - inputs: {}
    id: "2"
    configuration:
      type: application/javascript
      script: console.warn('Hello\nworld\nor\nearth!')
    type: script.ScriptAction

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request main ui Main UI
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Log Viewer] The logs from exceptions errors are converted to a single line
4 participants