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

Improve log display #3768

Merged
merged 2 commits into from
Jan 7, 2025
Merged

Conversation

AlanGreene
Copy link
Member

@AlanGreene AlanGreene commented Nov 22, 2024

Changes

Related to #2306
Resolves #3737

Add support for toggling display of timestamps in the logs, so the user no longer has to navigate away to the settings page to do this. This is available on both PipelineRun and TaskRun pages. We always request timestamps and just show / hide them depending on the user's preference. This is persisted to browser localStorage as with the toggle on the settings page.

Add support for detecting GitHub Actions workflow command-style log levels in log output. This provides an improved user experience as it allows for filtering logs to hide unwanted noise, e.g. debug logs, by default. We may consider allowing the format to be customised in a future release depending on user feedback.

Refactor the styles so LogFormat now correctly owns most of the styling of the log content, with Log only responsible for additional styling of the container.

Refactor use of the LogsToolbar component to allow for customisable use by third-party consumers of the Dashboard components. This means they can much more easily take advantage of the new features, such as toggling timestamps and log levels, without having to reimplement the menu and related code themselves.

Eliminate redundant use of split and join calls when processing the logs, improving performance. LogFormat now receives an array of log line objects, pre-parsed into the new structure with the timestamp, level (optional), and message fields. Where a multiline log is encountered, the timestamp of the first line is reused for subsequent lines in that log.

Fix issue where in some cases a blank line did not reserve vertical space, leading to cramped display of logs. Now each line is guaranteed to occupy a minimum height, ensuring blank lines output in the logs to aid in readability are preserved in the UI.

Update FormattedDate to add support for displaying seconds, as this is quite important in the log context. Default to false for this setting so existing date / timestamps in other parts of the UI are unaffected. The full raw timestamp as received in the logs in displayed in a tooltip on hover.

Update unit tests to reflect the new and changed components and behaviours.

Update common PipelineRun E2E to exercise the new log toolbar and validate the log content is rendered as expected.

Add new stories to cover the new functionality. Update existing stories to demonstrate use of the new functionality in context.

Update Carbon:

  • resolve issue with Plex Mono font

    Some glyphs weren't included in the Plex version packaged with previous Carbon releases, resulting in broken formatting for some log content, e.g. using box characters to print tables.

    In @carbon/react 1.71.0 the Plex version has been updated, as well as changing how it's consumed. Instead of a single package with all of the font variants, they're now published as separate packages per font family. Add the $use-per-family-plex flag to our config to use these new packages. The custom $font-path is still required for compatibility with Vite.

  • resolve issue with duplicate onChange events from MenuItemSelectable

  • resolve issue with duplicate onChange events when clearing a ComboBox

Notes:

  • colours of the log level badges are based on the colours of the Carbon Tag component, with their opacity reduced so they're not as intense due to the potentially large number of them that could be displayed in the logs. These all meet minimum colour contrast ratio required for WCAG 2.0 level AA (i.e. > 4.5:1).
  • the default log level is 'info' if no log level is explicitly provided in the logs, however we only display the badge when the log level is explicitly set. This avoids unnecessary and unwanted noise / clutter in the logs when not using the new log format.
  • highlight and hover state included to highlight log lines, aiding in consuming the content, especially with longer log lines where the log level badge may not be adjacent to the content being read. A future update to the log viewer will add support for line wrapping but this is out of scope for this particular change.

/kind feature
/kind design
/kind bug
/kind misc
/kind documentation

Submitter Checklist

As the author of this PR, please check off the items in this checklist:

  • Docs included if any changes are user facing
  • Tests included if any functionality added or changed
  • Follows the commit message standard
  • Meets the Tekton contributor standards (including
    functionality, content, code)
  • Has a kind label. You can add one by adding a comment on this PR that contains /kind <type>. Valid types are bug, cleanup, design, documentation, feature, flake, misc, question, tep
  • Release notes block below has been updated with any user facing changes (new features, significant UI changes, API changes, bug fixes, changes requiring upgrade notices or deprecation warnings)
  • Release notes contains the string "action required" if the change requires additional action from users switching to the new release

Release Notes

Add timestamp toggle and log level filtering to the log viewer.
The log viewer now supports GitHub Actions workflow command-style log levels in log output (e.g. `::warning::This is an important message…`), allowing for filtering logs to hide unwanted noise, e.g. debug logs, by default. If no log level is detected, the line is treated as `info` by default, but only lines with an explicitly set log level display the badge.

Supported commands are: `::error::`, `::warning::`, `::notice::`, `::info::`, and `::debug::`

@tekton-robot
Copy link
Contributor

Skipping CI for Draft Pull Request.
If you want CI signal for your change, please convert it to an actual PR.
You can still manually trigger a test run with /test all

@tekton-robot tekton-robot added do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. kind/feature Categorizes issue or PR as related to a new feature. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. kind/design Categorizes issue or PR as related to design. kind/bug Categorizes issue or PR as related to a bug. kind/misc Categorizes issue or PR as a miscellaneuous one. kind/documentation Categorizes issue or PR as related to documentation. labels Nov 22, 2024
@AlanGreene AlanGreene requested review from LyndseyBu and removed request for skaegi November 22, 2024 16:26
@AlanGreene
Copy link
Member Author

/test all

@AlanGreene
Copy link
Member Author

E2E failed on import resources test when selecting the import namespace. Not seeing the same issue locally, rerunning to see if it persists on prow

/test pull-tekton-dashboard-integration-tests

@AlanGreene
Copy link
Member Author

AlanGreene commented Nov 22, 2024

Failed in the same place. It's passing consistently locally, both in Electron and a real browser. Will need to debug next week…

@AlanGreene
Copy link
Member Author

/test pull-tekton-dashboard-integration-tests

Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

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

A few queries but overall looking good

src/containers/TaskRun/TaskRun.jsx Outdated Show resolved Hide resolved
src/containers/PipelineRun/PipelineRun.jsx Show resolved Hide resolved
src/containers/PipelineRun/PipelineRun.jsx Outdated Show resolved Hide resolved
src/api/utils.js Outdated Show resolved Hide resolved
src/containers/LogsToolbar/LogsToolbar.jsx Show resolved Hide resolved
@briangleeson

This comment was marked as resolved.

@AlanGreene

This comment was marked as resolved.

@AlanGreene

This comment was marked as resolved.

@AlanGreene AlanGreene force-pushed the logs_display_improvements branch 5 times, most recently from 08267d4 to fccf42d Compare December 4, 2024 12:04
@tekton-robot tekton-robot added the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Dec 9, 2024
@AlanGreene AlanGreene force-pushed the logs_display_improvements branch from fccf42d to ecf8913 Compare December 9, 2024 14:41
@tekton-robot tekton-robot removed the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Dec 9, 2024
@AlanGreene

This comment was marked as resolved.

@AlanGreene
Copy link
Member Author

/test all

Add support for toggling display of timestamps in the logs, so
the user no longer has to navigate away to the settings page
to do this. This is available on both PipelineRun and TaskRun
pages. We always request timestamps and just show / hide them
depending on the user's preference. This is persisted to browser
localStorage as with the toggle on the settings page.

Add support for detecting GitHub Actions workflow command-style
log levels in log output. This provides an improved user
experience as it allows for filtering logs to hide unwanted
noise, e.g. debug logs, by default. We may consider allowing
the format to be customised in a future release depending on
user feedback.

Refactor the styles so `LogFormat` now correctly owns most
of the styling of the log content, with `Log` only responsible
for additional styling of the container.

Refactor use of the `LogsToolbar` component to allow for
customisable use by third-party consumers of the Dashboard
components. This means they can much more easily take advantage
of the new features, such as toggling timestamps and log levels,
without having to reimplement the menu and related code themselves.

Eliminate redundant use of `split` and `join` calls when processing
the logs, improving performance. `LogFormat` now receives an
array of log line objects, pre-parsed into the new structure
with the `timestamp`, `level` (optional), and `message` fields.
Where a multiline log is encountered, the timestamp of the first
line is reused for subsequent lines in that log.

Fix issue where in some cases a blank line did not reserve vertical
space, leading to cramped display of logs. Now each line is
guaranteed to occupy a minimum height, ensuring blank lines
output in the logs to aid in readability are preserved in the UI.

Update `FormattedDate` to add support for displaying seconds, as
this is quite important in the log context. Default to `false` for
this setting so existing date / timestamps in other parts of the
UI are unaffected. The full raw timestamp as received in the logs
in displayed in a tooltip on hover.

Update unit tests to reflect the new and changed components and
behaviours.

Update common PipelineRun E2E to exercise the new log toolbar
and validate the log content is rendered as expected.

Add new stories to cover the new functionality. Update existing
stories to demonstrate use of the new functionality in context.

Update Carbon:
- resolve issue with Plex Mono font

  Some glyphs weren't included in the Plex version packaged with
  previous Carbon releases, resulting in broken formatting for some
  log content, e.g. using box characters to print tables.

  In `@carbon/react` 1.71.0 the Plex version has been updated, as well
  as changing how it's consumed. Instead of a single package with all
  of the font variants, they're now published as separate packages per
  font family. Add the `$use-per-family-plex` flag to our config to
  use these new packages. The custom `$font-path` is still required
  for compatibility with Vite.

- resolve issue with duplicate onChange events from MenuItemSelectable

- resolve issue with duplicate onChange events when clearing a ComboBox

- document the log viewer feature, the new log format, and the existing
  external logs support

Notes:
- colours of the log level badges are based on the colours of the
  Carbon `Tag` component, with their opacity reduced so they're
  not as intense due to the potentially large number of them that
  could be displayed in the logs. These all meet minimum colour
  contrast ratio required for WCAG 2.0 level AA (i.e. > 4.5:1).
- the default log level is 'info' if no log level is explicitly
  provided in the logs, however we only display the badge when
  the log level is explicitly set. This avoids unnecessary and
  unwanted noise / clutter in the logs when not using the new
  log format.
- highlight and hover state included to highlight log lines, aiding
  in consuming the content, especially with longer log lines where
  the log level badge may not be adjacent to the content being read.
  A future update to the log viewer will add support for line
  wrapping but this is out of scope for this particular change.
@AlanGreene AlanGreene force-pushed the logs_display_improvements branch from de7d7ab to 2803ac6 Compare December 10, 2024 11:58
@AlanGreene AlanGreene force-pushed the logs_display_improvements branch from 54112a2 to 8a1dcd7 Compare January 3, 2025 15:44
@AlanGreene AlanGreene marked this pull request as ready for review January 3, 2025 15:47
@tekton-robot tekton-robot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Jan 3, 2025
@AlanGreene AlanGreene removed the request for review from skaegi January 3, 2025 15:53
@AlanGreene AlanGreene force-pushed the logs_display_improvements branch from 8a1dcd7 to 5609e31 Compare January 3, 2025 15:54
@AlanGreene
Copy link
Member Author

AlanGreene commented Jan 3, 2025

Switched to new approach for the settings using a custom Popover component so the user can more easily make multiple changes. Also added a notice at the top of the logs when lines are hidden due to the currently selected log levels.

These changes are included in a separate commit for easier review.

@AlanGreene AlanGreene force-pushed the logs_display_improvements branch 4 times, most recently from 3a24173 to 7e46501 Compare January 3, 2025 17:08
Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

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

Looks good overall, thanks for the walkthrough. Just spotted some typos in the doc

docs/logs.md Outdated Show resolved Hide resolved
docs/logs.md Outdated Show resolved Hide resolved
Switch from the OverflowMenu to a custom Popover to improve the user
experience of toggling log levels. The OverflowMenu approach closes
the menu on each change requiring multiple additional clicks for each
log level the user wishes to toggle. With the Popover we can now keep
the menu open until explicitly dismissed, meaning users can much more
easily make multiple changes.

Also display a notice at the start of the logs if lines are hidden
due to the currently selected log levels.
@AlanGreene AlanGreene force-pushed the logs_display_improvements branch from 7e46501 to 11a3b7a Compare January 6, 2025 17:04
Copy link
Contributor

@briangleeson briangleeson left a comment

Choose a reason for hiding this comment

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

/lgtm

👍

@tekton-robot tekton-robot added the lgtm Indicates that a PR is ready to be merged. label Jan 6, 2025
@tekton-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: briangleeson

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@tekton-robot tekton-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Jan 6, 2025
@AlanGreene
Copy link
Member Author

/retest

@tekton-robot tekton-robot merged commit 158cc5b into tektoncd:main Jan 7, 2025
14 checks passed
@AlanGreene AlanGreene deleted the logs_display_improvements branch January 7, 2025 11:27
@AlanGreene AlanGreene mentioned this pull request Jan 20, 2025
7 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. kind/bug Categorizes issue or PR as related to a bug. kind/design Categorizes issue or PR as related to design. kind/documentation Categorizes issue or PR as related to documentation. kind/feature Categorizes issue or PR as related to a new feature. kind/misc Categorizes issue or PR as a miscellaneuous one. lgtm Indicates that a PR is ready to be merged. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Fully document external-logs feature
3 participants