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

Proposal to drive Diagnostics WG initiatives through user journeys #295

Open
hekike opened this issue Apr 22, 2019 · 14 comments
Open

Proposal to drive Diagnostics WG initiatives through user journeys #295

hekike opened this issue Apr 22, 2019 · 14 comments
Labels
diag-deepdive-agenda Used for agenda items related to diagnostic deep dive sessions never stale

Comments

@hekike
Copy link
Member

hekike commented Apr 22, 2019

Intro - Problem Statement

The Node.js Diagnostics WG members meet throughout the year to seek alignment on proposals and prioritize efforts in the Node.js diagnostics space. In the last Diagnostics Summit in Munich, March 2019, we identified that the working group doesn't have a clear articulation of the scope of use cases for users trying to diagnose problems with Node.js processes. The lack of a clear definition around supported diagnostics user journeys and the lack of alignment on long-term supported tooling and best practices lead to a fragmented tooling ecosystem with more than 25 Diagnostics WG identified tools.

This large surface area means that the community is spread thin in their efforts, while also creating an undue focus on specific tools and solutions. We propose that the WG should collect the user use cases, existing and ideal user journeys for our diagnostics solutions and tooling, as well as the gaps that exist, and use it to drive efforts to provide solutions like best practices and sufficient tooling over future LTS releases. We expect that shifting our focus to being more user-centric will help us to improve the runtime for the needs of various Node.js developers around diagnostics and facilitate the continued growth of Node.js adoption.

Goal

The goal of this proposal is to help the Diagnostics WG to prioritize work items and shape the next generation of tooling. We also believe that having a story for long term supported, cross-platform, stable, and developer friendly diagnostics tools will give enterprise companies more confidence in investing in Node.js as the runtime of choice for their use-cases. This can improve the number of meaningful contributions made to the various Node.js Foundation projects.

Proposal

The proposal is to collect and document the most common user journeys and recommended tools with pros and cons in specific scenarios and to highlight the existing tooling gaps today.

The current state of the proposal provides a template for collaborating on the use-cases with some draft around existing solutions and ideas for ideal user journeys.
Please check out the current version of the ongoing Node.js WG Diagnostics User Journeys document.

Recommended Next Steps

  • Seek alignment on goals
  • Agree on shifting focus from specific tools to long-term supported user journeys
  • Agree on supported workloads in the first round (API servers, workers etc.)
  • Agree on long-term user journey support over LTS releases
  • Agree on supported use-cases
  • Align on recommended tools for use-cases
  • Deep dive meetings per use-cases to create ideal user journeys
  • Move the content to GitHub repository
  • Use User Journeys to drive the Diagnostics Best Practices initiative
  • Regroup on tooling gap and create a long term vision for diagnostic tools

The upcoming Berlin Collaborator Summit could be a good place to seek alignment on some of the topics mentioned above.

Node.js WG Diagnostics User Journeys

@mcollina
Copy link
Member

Definitely +1.

@legendecas
Copy link
Member

Proposed some doc structures additional to #333 at #353.

@mmarchini
Copy link
Contributor

I just realized we're not covering WebAssembly diagnostics. This will probably be a good thing to address on a second version of the docs we're creating.

@RichardLitt
Copy link

I'm taking a look at this as someone who isn't heavily invested in the Diagnostics WG, in part to help give back after asking so many questions in #365.

As an external viewer, I don't know how this effort is going. Assuming that this thread and the documents it links to are the only resources, I think that there should be a way of getting quorum and agreeing to next steps. A lot of the steps in the initial comment are either already done, or don't have a clear path for resolution. Specifically:

  • Seek alignment on goals
  • Agree on shifting focus from specific tools to long-term supported user journeys
  • [~] Agree on supported workloads in the first round (API servers, workers etc.)
  • Agree on long-term user journey support over LTS releases
  • Agree on supported use-cases
  • Align on recommended tools for use-cases
  • Deep dive meetings per use-cases to create ideal user journeys
  • [~] Move the content to GitHub repository
  • Use User Journeys to drive the Diagnostics Best Practices initiative
  • Regroup on tooling gap and create a long term vision for diagnostic tools

These are done, that I can tell, with - [~] meaning in progress.

In order to move this forward, I would propose that the deep dive for use-cases doesn't happen at a live event (as that may not happen for a while, anyway), but instead happens collaboratively on a shared PR or document. Right now, the biggest blocker that I can see to this is that we don't have an example of what a deep dive should look like. All of the User Journey steps in this linked doc are marked TODO, which means that it's much harder for contributors to imagine what they ought to look like.

Can we make the next step in this process to be:

  • Collaboratively write up a single, complete User Journey test case

I suggest the My application doesn’t behave as expected journey, as that is first in the doc and seems to be fairly low-hanging fruit. Ideally, this question should be raised at the next WG meeting, and then someone should volunteer or be assigned as a DRI to have a first draft ready for the next WG, with comments edited in or assumed done at the second WG afterwards. Does that sound like an actionable plan for moving this effort forward?

Hope this helps.

@mmarchini
Copy link
Contributor

Hi @RichardLitt, thank you for investing time on this!

I suggest the My application doesn’t behave as expected journey, as that is first in the doc and seems to be fairly low-hanging fruit. Ideally, this question should be raised at the next WG meeting, and then someone should volunteer or be assigned as a DRI to have a first draft ready for the next WG, with comments edited in or assumed done at the second WG afterwards. Does that sound like an actionable plan for moving this effort forward?

We haven't updated this issue, but we've been doing this for the past few months now during our WG meetings (except when we have a packed agenda, like the last meeting). Since most of us don't have time to commit outside of the meeting to write such documents, working on those collaboratively during the meeting has proven very effective.

I forgot where these docs are though 😅. Maybe @gireeshpunathil or @hekike will be able to answer it better.

@RichardLitt
Copy link

Awesome! Glad that this is moving forward, and I hope hoping the information here will help others know that is going on (may be surplus). :)

@mmarchini
Copy link
Contributor

Removed from the agenda since we decided to meet for deep dives on User Journeys every other week. Will re-add if the initiative stalls.

@mmarchini
Copy link
Contributor

@github-actions
Copy link

This issue is stale because it has been open many days with no activity. It will be closed soon unless the stale label is removed or a comment is made.

@github-actions github-actions bot added the stale label Aug 12, 2020
@mmarchini
Copy link
Contributor

bad bot

@mmarchini mmarchini added diag-deepdive-agenda Used for agenda items related to diagnostic deep dive sessions never stale and removed stale labels Aug 12, 2020
@github-actions
Copy link

This issue is stale because it has been open many days with no activity. It will be closed soon unless the stale label is removed or a comment is made.

@github-actions github-actions bot added the stale label Jul 23, 2022
@gireeshpunathil
Copy link
Member

still relevant

@RafaelGSS RafaelGSS removed the stale label Jul 23, 2022
@github-actions
Copy link

This issue is stale because it has been open many days with no activity. It will be closed soon unless the stale label is removed or a comment is made.

@github-actions github-actions bot added the stale label Oct 22, 2022
@github-actions github-actions bot removed the stale label Nov 3, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
diag-deepdive-agenda Used for agenda items related to diagnostic deep dive sessions never stale
Projects
None yet
Development

No branches or pull requests

8 participants
@mcollina @RichardLitt @hekike @mmarchini @gireeshpunathil @legendecas @RafaelGSS and others