-
-
Notifications
You must be signed in to change notification settings - Fork 3.3k
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
feat(automatic-release): Generation of automatic release #1017
Conversation
We don't do official releases for the docs. How would this work exactly? |
it will give you the ability to generate a changelog automatically. It looks at all the commits between the previous version, computes bugs, features, ... and write it to CHANGELOG.md. It also tags the newly created commit so you can easily publish to npm. It might not make much sense for docs to use this. Feel free to reject ;) |
Yeah, I understand the point of changelog generation. It's just that we don't bump the version of the site ever. |
I can change the package to use conventional-changelog-cli so it only generates a changelog without bumping the npm version. Or if you're not interested than just close the PR 👍. Just added this to all repos 😄 |
Sure, I'll think about it. Let's leave this open for other comments to see if people want to read change logs on docs. |
I think this is interesting... I'm about to start using standard-version/conventional-changelog on a few other projects. That said though I'm 100% not sure it would work here, some thoughts:
I'd be interested to see some changelogs for other large documentation sites if anyone has an example. |
the thing with PR is you can rewrite the commit message when you're going to merge so you can fix commits that way but it extra work for the maintainers. I do get the point that it doesn't make much sense for documentation but never the less it might be handy to see how the repo is changing without having to go through each commit message? |
@wardpeet @bebraw I'm going to close this for now as I think it might still be a little ways off before we implement. However I think we should...
@bebraw feel free to re-open if you think I'm being too hasty here, I think we should implement this but first see if we can follow the convention for a bit. Also how would we version this repo? According to commits and changes or maybe have it trail the current webpack version (e.g. once a new webpack release has been fully documented, cut a release here as well with the same version #). |
Most likely we would sync releases with webpack versioning. Done right, this would be a chance to write archives for older versions online (little gh-pages script). The hardest part is forcing all commits to follow a certain convention. That rules out casual commits in PRs but that's not necessarily a bad thing. |
Yea I was thinking the same thing. In my mind the tasks we need to accomplish before this can happen are:
I think if we can get this repo to a point where we don't have a whole bunch of core doc issues open then we can start looking into this more. Workflow would be something like: webpack release => new issues and prs to document the release => webpack.js.org release
True but as @wardpeet mentioned we can use the squash and merge option on PRs to rewrite commits. I think it's more that we as the maintainers would have to consistently remember to do it. However, with something like conventional-changelog-lint (soon to be commitlint) in the CI process, maybe it wouldn't be too hard. |
I would go with the latest version only. Implementing dropdowns for loaders/plugins feels like expensive to implement given how many pages you would have to write during generation (unless archives work in a smart way). |
@bebraw yep I agree. Well at least we've landed on a general plan. Let's revisit this once our issue count is down and more of the core content is fleshed out. |
@wardpeet I think we're slowly starting to follow the convention more and more. The "Squash and Merge" option you mentioned has been very useful indeed. Out of curiosity, have you implemented anything like conventional-changelog-lint into a build/ci process? We could enforce the convention this way but I'm not sure how that would handle "Squash and Merge" where we're actually rewriting the commit in github prior to merging. Just interested in your thoughts on this... |
@skipjack commitlint as a CLI to be executed during CI is not suited very well to the "Squash and Merge" case. @paulirish and @ahmed-taj came up with early commitlint bots that add a status to an PR based on the PR title - using those you end up conforming squash commits "by default".
Is this something you are still interested in? |
commitlint is used at lighthouse and works great! |
@marionebl yes it definitely is, I've been using
Currently, the process I follow for PRs with multiple commits is basically:
It looks like the first of the two bots you mentioned would be perfect as it would quickly answer that second question for us. |
@skipjack would you like me to set this up in a PR? If you want more categories we could have a look at https://github.com/leonardoanalista/cz-customizable where you can configure these categories to better match webpack |
@wardpeet that would be great but wouldn't you need admin access to set up the bot? Also, which bot were you thinking about setting up? I think the first one @marionebl pointed out would be perfect: https://github.com/ahmed-taj/commitlint-bot |
@skipjack i can do it on my fork to start from ;) |
Great, yeah please feel free to submit one then. |
One disclaimer: the bots don't support custom config yet, I am preparing support for this on the commitlint side of things: https://github.com/marionebl/commitlint/pull/169 Idea how this could work here: z0al/commitlint-bot#1 (comment) |
@marionebl that’s fine, we pretty much just follow the conventionalcommits standard but we would probably customize it a little down the road. |
No description provided.