This repository has been archived by the owner on Dec 1, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
docs: add H2 2023 roadmap #82
Merged
Merged
Changes from 8 commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
34d1ebf
docs: add H2 2023 roadmap
galargh f4417e1
fix: roadmap workflow after testing
galargh 41c7abe
chore: apply suggestions from code self-review
galargh f3b2079
Update ROADMAP.md
galargh dd68542
Update ROADMAP.md
galargh 5cc571e
docs: update self-hosted runners section in ROADMAP.md
galargh eec4a88
docs: update the uCI section of the ROADMAP.md
galargh d933c02
docs: update exploration section of the ROADMAP.md
galargh bdc49d0
docs: update the uCI section of the ROADMAP.md
galargh File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
on: | ||
push: | ||
branches: | ||
- main | ||
paths: | ||
- ROADMAP.md | ||
- .github/workflows/roadmap.yml | ||
workflow_dispatch: | ||
|
||
defaults: | ||
run: | ||
shell: bash | ||
jobs: | ||
roadmap: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/github-script@v6 | ||
with: | ||
script: | | ||
const owner = context.repo.owner; | ||
const repo = context.repo.repo; | ||
|
||
const issues = await github.paginate(github.rest.issues.listForRepo, {owner, repo}); | ||
|
||
const fs = require('fs'); | ||
const roadmap = fs.readFileSync('ROADMAP.md', 'utf8'); | ||
|
||
var issue | ||
var title = '' | ||
var body = '' | ||
|
||
const milestones = [] | ||
for (const line of roadmap.split('\n')) { | ||
if (line.startsWith('## ')) { | ||
if (title) { | ||
const link = title.toLowerCase().replace(/[\s]/g, '-').replace(/[^\w-]/g, ''); | ||
body = `description: https://github.com/${owner}/${repo}/blob/master/ROADMAP.md#${link}\n\n` + | ||
`---\n\n${body}`; | ||
milestones.push({ title, body }); | ||
} | ||
title = line.replace('## ', ''); | ||
body = ''; | ||
} else { | ||
body += `${line}\n`; | ||
} | ||
} | ||
if (title) { | ||
milestones.push({ title, body }); | ||
} | ||
|
||
const children = [] | ||
for (const {title, body} of milestones) { | ||
issue = issues.find(issue => issue.title === title); | ||
if (issue) { | ||
await github.rest.issues.update({ | ||
owner, | ||
repo, | ||
issue_number: issue.number, | ||
body: `${issue.body.split('---')[0]}\n---\n${body}`, | ||
labels: ['starmaps'], | ||
}); | ||
} else { | ||
issue = (await github.rest.issues.create({ | ||
owner, | ||
repo, | ||
title, | ||
body: `<!-- The content above will **NOT** be modified by automation. -->\n\n---\n\n${body}`, | ||
labels: ['starmaps'], | ||
})).data; | ||
} | ||
children.push(issue.html_url); | ||
} | ||
|
||
title = roadmap.split('\n')[0].replace('# ', ''); | ||
body = `description: https://github.com/${owner}/${repo}/blob/master/ROADMAP.md\n` + | ||
`children:\n${children.map(child => ` - ${child}`).join('\n')}\n` + | ||
`---\n\n${roadmap}`; | ||
|
||
issue = issues.find(issue => issue.title === title); | ||
if (issue) { | ||
await github.rest.issues.update({ | ||
owner, | ||
repo, | ||
issue_number: issue.number, | ||
body: issue.body.split('---')[0] + '\n---\n' + body, | ||
labels: ['starmaps'], | ||
}); | ||
} else { | ||
await github.rest.issues.create({ | ||
owner, | ||
repo, | ||
title, | ||
body: '<!-- The content above will **NOT** be modified by automation. -->\n\n---\n\n' + body, | ||
labels: ['starmaps'], | ||
}); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
# IPDX Roadmap H2 2023 | ||
|
||
Given our mode of operation and the fact that we are highly affected by current needs of teams, our H2 roadmap serves mainly us a guideline of where our interests lie and where we'd like to focus our efforts. We view our adaptability as one of our main strengths but it also means we have to be flexible when it comes to our planning. If you already know of things you'd like our involvement for in H2 2023, please let us know - we're happy to adjust accordingly. We're here for you ❤️ | ||
|
||
## Drive GitHub Observability Usage Internally | ||
|
||
Whenever applicable, every project we start in H2 2023 should have a Grafana Dashboard associated with it that tracks relevant metrics for the project. Each project issue should have a link to the dashboard, description of the metrics we care about and the expected outcomes. | ||
|
||
Additionally, we'd like to use GitHub Observability to identify more workflows that would benefit from PL Self-Hosted Runners. | ||
|
||
## Release Gateway Conformance v1 | ||
|
||
In H2 we want to conclude IPDX's active development of Gateway Conformance. Ideally, we'd like to attract Gateway implementation maintainers to become active contributors to the project. We're going to continue to serve as maintainers, review PRs and provide guidance. | ||
|
||
To be able to call Gateway Conformance ready for this, we should: | ||
- achieve test coverage parity with Kubo sharness tests | ||
- improve DX/UX around test expectations and names | ||
- start running Gateway Conformance against a gateway external to PL | ||
|
||
In terms of promotion of Gateway Conformance, we'd like to: | ||
- give a talk about Gateway Conformance during IPFS Camp | ||
- continue support of using Gateway Conformance in project Rhea | ||
|
||
As stretch goals for the Gateway Conformance initiative, we identified: | ||
- closer integration with specs repository/IPIP process | ||
- creation of dashboard encompassing all gateway implementations | ||
galargh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
## Increase PL Self-Hosted Runners Relevance | ||
|
||
With the recent $ cost reduction efforts in the PL self-hosted runners space the project is well positioned to serve the needs of PL developers already i.e. we feel confident it's the correct solution to apply to increase developer speed when faced with GitHub hosted runners bottleneck problem. As of now there are 2 areas that we'd like to look more closely into: | ||
- windows runners (we already had them set up at the beginning so it's just a matter of resurrecting the configuration) | ||
- decreasing boot time (currently the runners take up to 2 minutes to boot up) | ||
|
||
## Expand IPDX Comms | ||
|
||
We want to continue living close to our developers. That's why we're going to continue releasing **What's new in GitHub?** issues on a monthly basis. What's more, we'd like to start a new regular newsletter about productivity tips. Finally, we'd like to start tracking [developer happiness](https://github.blog/2023-06-08-developer-experience-what-is-it-and-why-should-you-care/) among IP Stewards. To begin with, we're going to prepare surveys for IP Stewards developers that are going to be issued on a regular basis. | ||
|
||
When it comes to external comms, we'd like to actively participate in IPFS Camp and GitHub Universe conferences. | ||
|
||
## Release Unified CI 2.0 | ||
|
||
In August, we're going to release new version of Unified CI with Go 1.21 support. With that release, we'd like to transition to [Unified CI 2.0](https://github.com/protocol/.github/issues/514) which should encompass all the learning that we gathered by running Unified CI in its' current form for years. This includes but is not limited to: | ||
galargh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
- versioning Unified CI | ||
- embracing reusable workflows | ||
- centralising auomerge functionality | ||
- allowing configurability through dot files | ||
- simplifying enrollment with invite to deploy strategy | ||
|
||
All of the above will make Unified CI more robust, easier to manage and it will increase it chances to last for another couple of years. Moreover, it will open up doors for even more automation across hundreds of repositories, like using dependabot (instead of web3-bot that has to be maintained by IPDX) for Unified CI updates for example. | ||
galargh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
## Immerse Into the Day to Day of IP JS Developer | ||
|
||
As one of the most under-resourced projects within IP Stewards group, it is the best target for our research. We want to embed with the team for a while to uncover areas of potential DX improvements. By the end of this exercise, we want to have a concrete, prioritised list of improvements that would make the life of a IP JS developer easier. | ||
|
||
## Improve the Day to Day of Kubo/Boxo Developer | ||
|
||
We've been focusing on Kubo/Boxo developers in H1 2023. In H2, we'd like to work on the work items that we identified throughout the process. The main projects we envision are: | ||
- create a general solution for identifying flaky tests within Go ecosystem | ||
- create a general solution for [enforcing constraints on dependencies within Go ecosystem](https://github.com/pl-strflt/ipdx/issues/80) | ||
- automate CHANGELOG update reminders | ||
- fix the shortcomings of testing and coverage at the cross section of Kubo and Boxo | ||
- deprecate sharness tests | ||
- execute kuboreleaser in GitHub Actions | ||
|
||
## Explore DX of Building on IPFS Stack | ||
galargh marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
A major push around debuggability within our stack is expected to happen. This is a great opportunity to kick start a joint effort between Kubo, Helia, IPDX, and probelab. | ||
|
||
Through our work on Gateway Conformance we discovered that building on IPFS stack is not easy, even for people close to the ecosystem. We'd like to start a standalone project that would help us explore this further. The very rough game plan is: | ||
1. Start a simple project that cuts through all the layers of IPFS stack (working idea - decentralised DropBox). | ||
2. Consume the publicly available documentation to implement the project. | ||
3. Document usability sharp edges and documentation shortcomings. | ||
4. Contribute usability fixes to the IPFS stack. | ||
|
||
Our thinking is that this exercise could attract more active contributors to the IPFS stack thus reducing strain on IP Stewards. | ||
|
||
This is a project that sparks joy for Laurent 💖 | ||
laurentsenta marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
## Increase GitHub Security | ||
|
||
We want to continue building up our partnership with RSS by continuous collaboration on Security Guides for Software Engineers. Moreover, we'd like to explore the possibility of: | ||
- deploying dependabot for updating GitHub Actions to all PL repositories | ||
- enabling Code Scanning with default settings in all PL repositories | ||
|
||
## R&D | ||
|
||
We want to continue bringing innovation and improvement to our development stack. To be able to do that, we need to be up-to-date with the latest tech in the field. We'll definitely continue exploring AI tooling throughout the rest of the year and evaluate its' relevance for our projects. Moreover, we'd like to gain practical experience with GitHub merge queues by integrating them in GitHub Management workflows. |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@laurentsenta Here, we're looking for issues by title (extracted from markdown). With your proposal of embedding the linking back into markdown this could be improved. Side note, we won't have to worry about infinite workflow triggers either. GHA will prevent that from happening. When we push to ROADMAP.md as GHA, the workflow will not start again.