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

chore: Add wikibase-lts and deploy-lts products #813

Draft
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

lorenjohnson
Copy link
Contributor

@lorenjohnson lorenjohnson commented Jan 6, 2025

Moves our Wikibase and Deploy LTS products beside our main releases of these products all in one repo. This reduces complexity, and solves a number of problems. The work in this branch completes much of what is needed to take this path, with the following remaining to be decided/addressed.

  • Decide if we really want to just tag lts-x.y.z on Dockerhub or use wikibase-lts as a new image (doesn't require any release configuration change)
  • Update testing setup such the tests run on both LTS products as well as latest product releases.
    • Stretch goal: Run tests on both versions only when changes to the LTS products are detected, perhaps utilising nx affected.

Note: This branch includes a the yet unreleased Wikibase LTS 1.0.1 (MediaWiki 1.39.10 patch release), and the related Deploy LTS 1.0.1 releases already prepared including CHANGELOG updates (review those to see the format used).

@lorenjohnson
Copy link
Contributor Author

NX release does the right thing 🥳:

image

@lorenjohnson
Copy link
Contributor Author

lorenjohnson commented Jan 6, 2025

A couple of notes after looking into things a bit more today:

  • After a bit of poking I have a pretty clear idea of how to amend the test setup to work well with this setup and only run LTS tests when there are changes in the LTS releases from the last release.

  • To highlight the perhaps obvious, if we were go this direction we can at any time inspect the diff between build/wikibase and build/wikibase-lts (to see what we might want or need to back port) by running git diff --no-index build/wikibase-lts build/wikibase, or a little more recklessly simply copying the contents of build/wikibase over build/wikibase-lts then do a git diff. Same for deploy and deploy-its of course. Git is our friend.


### 🏡 Chore

- bump mediawiki to 1.42.3, bump extensions
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
- bump mediawiki to 1.42.3, bump extensions
- bump mediawiki to 1.39.10, bump extensions


- bump mediawiki to 1.42.3, bump extensions

## (from **[email protected]** (2024-10-09))
Copy link
Contributor

Choose a reason for hiding this comment

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

I am unsure whether we really want to include this information. Going forward, NX wouldn't generate it either. I think I would prefer just the list of changes since [email protected]


### 📖 Documentation

- Link to MediaWiki bundled extensions
Copy link
Contributor

@rti rti Jan 7, 2025

Choose a reason for hiding this comment

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

Just to spell it out once here: So whenever we change something on the wikibase product in the future, we always have to consider bringing it to lts too, right when we implement the change, review and merge it. In case we decide the change goes to latest and lts, we would apply the same change to both directories in the same PR, so NX would generate the same changelog entry for any of the both products whenever we release the next version.

I like this.

@rti
Copy link
Contributor

rti commented Jan 7, 2025

Decide if we really want to just tag lts-x.y.z on Dockerhub or use wikibase-lts as a new image (doesn't require any release configuration change)

I am still sympathizing with the idea to make wikibase and wikibase-lts one product on dockerhub. This is how the process could look like:

  • Currently we maintain Wikibase 3.0.2 and Wikibase 1.0.0
  • With this approach
    • Wikibase 3.0.2 (Mediawiki 1.42) would live in the build/wikibase directory as the wikibase "nx project", tagged with [email protected] git tags
    • Wikibase 1.0.0 (Mediawiki 1.39 - LTS) would live in the build/wikibase-lts directory as the wikibase-lts "nx project", tagged with [email protected] git tags
    • Patching Wikibase 3 would happen in the build/wikibase directory and eventually lead to a release git tagged with [email protected]
    • Patching Wikibase 1 would happen in the build/wikibase-lts directory and lead to a release git tagged with [email protected]
    • Now What happens when we release a wikibase based on 1.43? (anytime from now)
      • Mediawiki 1.39 is still supported, so we probably should support it too, so Wikibase 1 will continue to receive patches in the wikibase-lts directory
      • Mediawiki 1.43 will be released with Wikibase 4 from the wikibase directory.
      • Note that Mediawiki 1.43 is a LTS version...
    • Now What happens when we release a wikibase based on 1.44? (some time in summer)
      • Mediawiki 1.44 will be released with Wikibase 5 from the wikibase directory.
      • Mediawiki 1.43 was an LTS version, so we can build our LTS version based on that too
      • We could copy the 1.43 based build/wikibase directory to build/wikibase-lts and continue maintaining it there, continuing with version number 4, as [email protected]

The switch from "released from build/wikibase" to "released from build/wikibase-lts" could be opaque to the user if we push from both "nx projects" to the same "dockerhub project" maintaining a consistent versioning throughout the full product lifecycle.

So users could onboard to Wikibase 4 now as soon as we release it and keep using it for years as long as we keep it in lts support. That we change the build folder name over time would not be relevant for the user.

I do agree though, that we need some special handling for the wikibase-lts git tag then. I wondered if we could have a new workflow triggered by [email protected] git tags. This workflow could just tag [email protected] and push it to the repo to trigger the original publish workflow. Is this a hack or clever design? ;)

This is raw thoughts dumped here, I might be missing something, or even a whole lot. The purpose of this comment is to further fuel the discussion.

@lorenjohnson
Copy link
Contributor Author

lorenjohnson commented Jan 7, 2025

After more discussion the conclusion for now is to keep the wikibase naming for the product for both git tags and docker hub releases. This requires maybe only adding an exception here:

IMAGE_NAME=$(jq -r '.name' package.json)

...for wikibase-lts to make the IMAGE_NAME wikibase

@rti
Copy link
Contributor

rti commented Jan 9, 2025

After more discussion the conclusion for now is to keep the wikibase naming for the product for both git tags and docker hub releases.

I am not so sure. In my latest mental model, we only merge the LTS and non-LTS product on dockerhub. But in the NX/git world, they would be two products. Especially to have NX properly derive versions from git tags

@@ -71,9 +71,12 @@ else
)
fi

# transform TAGS to build args
IMAGE_NAME=$(jq -r '.name' package.json)
Copy link
Contributor

Choose a reason for hiding this comment

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

Could we also just change the name in package.json? Without any code change?

Copy link
Contributor

Choose a reason for hiding this comment

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

No, I think this is not a good idea. I think we need to keep the -lts around until we finally publish to dockerhub only. Otherwise we need to change too many things, e.g. local image versioning vs latest only, how to identify images when pushed to/pulled from GHCR...

@lorenjohnson
Copy link
Contributor Author

lorenjohnson commented Jan 10, 2025

@rti following along with #815 👍🏼

I was digesting this all a bit more yesterday, and doing a little research on how nx themselves manage their own LTS version. They use minor version branches such as 19.3.x. The more I rewound to looking at our options, the more I flip again to thinking we would be best to just have an LTS branch.

After digesting I realised that I had become convinced that LTS is in fact not a separate product, but simply as an earlier version of the Wikibase product. You helped me see that it is in fact only that, and that this will become evident sometime when LTS becomes 1.43 that our [email protected] releases are our LTS releases.

It is looking to me now like the two directory version of things here is only solving one problem we encountered: ./nx release version generation of the expected version number. Creating wikibase-lts as a separate product puts it on its own version path, instead of looking to wikibase to get that version number and ending-up always trying to version as a next version of latest.

However, I think what we're doing otherwise is actually again adding complexity where it needs not be there. I don't think it actually results in a simplified workflow for releases nor make anything possible that wasn't before with 2 branches.

Here is what I think should be our priorities right now:

  • Addressing the issue with ./nx release version generating the correct version number on an lts branch
  • Review/update our internal documentation on how to make releases
  • Clear-up and make coherent our comms story such that we can start automatising LTS patch releases (as I think that is the only thing in the way of it)

@rti
Copy link
Contributor

rti commented Jan 10, 2025

@lorenjohnson I am not convinced. I still like the approach to only have one branch and I think it does make things simpler. It is a bit of a compromise, but the alternative to maintain more branches also does not come without compromises. We had it for a while. I would really like to try the single branch approach now and learn from it.

One part why the single branch, lts-product approach still has quite some appeal for me is how @RickiJay-WMDE put it: "This is a mono repo thing". It just makes sense how we set up the repo now. Branching the whole directory structure would be weird because we would have elasticsearch, quickstatements, all the tests, etc. in two branches, but they are actually always in sync. So this would be constant merging or cherry picking (as we had it). NX also gets hick ups, not only for version choosing but also for changelog generation, and depending on a patched version of nx could complicate things too.

@rti
Copy link
Contributor

rti commented Jan 10, 2025

@lorenjohnson Tests for LTS and latest are passing over here in #815. Would love to hear what you think about the actual changeset.

@lorenjohnson
Copy link
Contributor Author

That's fine. I did a write-up of much more careful evaluation of each scenario yesterday, including the procedure for how the lts branch would be managed and then closed a browser window on accident and lost it 😢 So this second pass I didn't work that hard to make the case clear here, but I do think that we are basically making a new bit of complexity (tolerable in this case) due to simply not having made clear decisions and documentation on the 2 branch workflow. We were in sync when we decided to check out this 2 directory solution, and I was excited about it. I came to another perspective since and I'd like to come back and chat about it more until we arrive back at the same page again. I can be won back over, but I saw things in reflection that felt pretty clear and they are just hard to lay out here in comments readily.

Yes, I will lave comments on your code too.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants