Project

General

Profile

Actions

Support #18874

closed

Merge workbench2 history into main Arvados repo

Added by Peter Amstutz almost 3 years ago. Updated 9 months ago.

Status:
Resolved
Priority:
Normal
Assigned To:
Category:
Workbench2
Due date:
Story points:
3.0
Release:
Release relationship:
Auto

Description

Import entire workbench2 history into main Arvados repo.

Want to preserve the commit hashes, so wb2 history will go back to a different root commit.

Merge point will move workbench2 to arvados/apps/workbench2

Update build scripts, arvados-boot, arvbox etc to reflect new location of workbench2 inside the main tree.

From discussion:

Tom will figure out the git merge and updating run-tests to be able to perform the workbench2 tests.

Once this is ready Tom & Lucas will update Jenkins & other scripts (eg package building).

Updating services/workbench2 during transition period

Temporarily (after the initial subtree merge into the arvados repo, but before we have stopped pushing changes to the workbench2 repo) this is the recipe for syncing changes from main workbench2.git to main arvados.git/services/workbench2:

$ git fetch git@git.arvados.org:arvados-workbench2 main:workbench2-main
$ git subtree merge -P services/workbench2 workbench2-main

Use a commit message like this, to satisfy git.arvados.org policies:

Merge branch 'main' from workbench2.git

refs #18874

Arvados-DCO-1.1-Signed-off-by: Tom Clegg <tom@curii.com>

Transition progress

steps:
  • ✅ add Jenkins jobs for testing the version of workbench2 in the arvados repo
  • ✅ merge latest main branch of workbench2 into the arvados tree at services/workbench2/ using git-subtree
  • ✅ use the new arvados-server install to rebuild the machine image jenkins uses to run arvados tests (see ENOSPC note above)
  • ✅ run Jenkins jobs manually, fix any other problems that still prevent services/workbench2 tests from passing
  • ✅ configure Jenkins to run the new workbench2 tests as part of the developer-run-tests and run-tests pipelines
  • ✅ update arvbox to use checked-out services/workbench2 instead of arvados-workbench2.git
  • ✅ update debian package-building to build workbench2 packages from arvados.git/services/workbench2
  • ✅ stop building packages from arvados-workbench2.git
  • ✅ merge latest main branch from arvados-workbench2.git into arvados.git/services/workbench2
  • ✅ prohibit pushing updates to main branch at arvados-workbench2.git (from now on devs will push to arvados.git/services/workbench2 instead)

Subtasks 3 (0 open3 closed)

Task #20871: Review 18874-merge-wb2ResolvedLucas Di Pentima09/28/2023Actions
Task #21161: Update jenkins build imageResolvedLucas Di Pentima09/28/2023Actions
Task #21192: Review 18874-merge-wb2ResolvedTom Clegg09/28/2023Actions

Related issues 2 (0 open2 closed)

Related to Arvados Epics - Idea #17001: Arvados uses WB2 by defaultResolvedActions
Blocked by Arvados - Support #18873: Add hooks to limit which paths of arvados repo non-curii employees can push toResolvedWard VandewegeActions
Actions #1

Updated by Peter Amstutz almost 3 years ago

  • Blocked by Support #18873: Add hooks to limit which paths of arvados repo non-curii employees can push to added
Actions #2

Updated by Peter Amstutz almost 3 years ago

  • Target version set to Kanban
Actions #3

Updated by Peter Amstutz almost 3 years ago

  • Target version changed from Kanban to 2022-04-27 Sprint
  • Project changed from 40 to Arvados
Actions #4

Updated by Peter Amstutz almost 3 years ago

  • Target version changed from 2022-04-27 Sprint to 2022-05-11 sprint
Actions #5

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-05-11 sprint to 2022-05-25 sprint
Actions #6

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-05-25 sprint to 2022-06-08 sprint
Actions #7

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-06-08 sprint to 2022-06-22 Sprint
Actions #8

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-06-22 Sprint to 2022-07-06
Actions #9

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-07-06 to 2022-07-20
Actions #10

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-07-20 to 2022-08-03 Sprint
Actions #11

Updated by Peter Amstutz over 2 years ago

  • Category set to Workbench2
Actions #12

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-08-03 Sprint to 2022-08-17 sprint
Actions #13

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-08-17 sprint to 2022-08-31 sprint
Actions #14

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-08-31 sprint to 2022-09-14 sprint
Actions #15

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-09-14 sprint to 2022-09-28 sprint
Actions #16

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-09-28 sprint to 2022-10-12 sprint
Actions #17

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-10-12 sprint to 2022-10-26 sprint
Actions #18

Updated by Peter Amstutz over 2 years ago

  • Target version changed from 2022-10-26 sprint to 2022-11-09 sprint
Actions #19

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2022-11-09 sprint to 2022-11-23 sprint
Actions #20

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2022-11-23 sprint to 2022-12-07 Sprint
Actions #21

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2022-12-07 Sprint to 2022-12-21 Sprint
Actions #22

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2022-12-21 Sprint to 2023-01-18 sprint
Actions #23

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2023-01-18 sprint to 2023-02-01 sprint
Actions #24

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2023-02-01 sprint to 2023-02-15 sprint
Actions #25

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2023-02-15 sprint to 2023-02-01 sprint
Actions #26

Updated by Peter Amstutz about 2 years ago

  • Target version changed from 2023-02-01 sprint to Future
Actions #27

Updated by Lucas Di Pentima almost 2 years ago

  • Assigned To set to Lucas Di Pentima
Actions #28

Updated by Lucas Di Pentima almost 2 years ago

  • Story points set to 1.0

The most potentially complex task in my eyes would be the repository merge, but it seems it's totally doable. This SO question has some clues about how to do it:

https://stackoverflow.com/questions/1425892/how-do-you-merge-two-git-repositories

In the past we talked about using the wb2 repo as a submodule of the arvados repo, but I think it would be more useful in this case to just merge it like explained in this answer:

https://stackoverflow.com/a/10548919

...the feature explained here seemingly allows keeping both histories.

So with that out of the way, I think it would take a full point to update the build scripts, CI pipelines, and so on.

Actions #29

Updated by Peter Amstutz over 1 year ago

  • Related to Idea #17001: Arvados uses WB2 by default added
Actions #30

Updated by Peter Amstutz over 1 year ago

  • Story points changed from 1.0 to 3.0
  • Target version changed from Future to Development 2023-08-30
  • Assigned To changed from Lucas Di Pentima to Tom Clegg
Actions #31

Updated by Peter Amstutz over 1 year ago

  • Description updated (diff)
Actions #32

Updated by Tom Clegg over 1 year ago

18874-merge-wb2 @ 102fefc02fecec15d801d3d457aad8148be89dbc -- developer-run-tests: #3795

18874-merge-wb2 @ bfaee40696c3c15556ef089e69da47bb832b08db -- developer-run-tests: #3801

18874-merge-wb2 @ 608f3e19607e00b76ef9fb8cedef8124a31ceff7 -- developer-run-tests: #3802

18874-merge-wb2 @ 608f3e19607e00b76ef9fb8cedef8124a31ceff7 -- developer-run-tests: #3804

Status:

Jenkins "remainder" test configs are updated to skip wb2.

Jenkins jobs for testing wb2 are added (but not yet attached to the main run-tests jobs as dependencies).

wb2 unit tests pass.

wb2 integration tests fail:

Error: ENOSPC: System limit for number of file watchers reached, watch '/tmp/workspace/developer-run-tests-services-workbench2/services/workbench2/public/webshell/README'

I updated arvados-server install to do the "fs.inotify.max_user_watches thing":Running tests to avoid that.

I think it would make sense to merge this to main, then update the Jenkins worker image using the new arvados-server install in order to get the fs.inotify.max_user_watches thing fixed, then see what else needs to be done to make integration tests pass.

Actions #33

Updated by Tom Clegg over 1 year ago

Now that this branch merges a subtree and then main, I don't know a single git command to show the succinct diff. But this gives the changes I made to the workbench2 tree:

git diff 2f83fcd45b...18874-merge-wb2

...and this shows the changes I made to the arvados tree:

git diff 29ad3b7333...18874-merge-wb2 lib build .licenseignore

I made two changes to the workbench2 test scripts that might affect other dev workflows.

I modified Makefile so make unit-tests and make yarn-install don't implicitly run arvados-server install, which requires root. I updated the *-tests-in-docker rules so they run make arvados-server-install in the container explicitly.

I modified tools/run-integration-tests.sh so it doesn't try to build arvados-server or run arvados-server install if the arvados-server binary already exists in GOPATH. I suspect these steps shouldn't be there at all -- shouldn't the caller be running "make arvados-server-install" explicitly if they want to update apt dependencies etc.?

Actions #34

Updated by Peter Amstutz over 1 year ago

  • Target version changed from Development 2023-08-30 to Development 2023-09-13 sprint
Actions #35

Updated by Tom Clegg over 1 year ago

Offline we decided we don't want to merge this before 2.7. It wouldn't affect anything functionally, but we might as well avoid creating extra risk of confusion by having workbench2 code in the arvados source tree that's tagged 2.7 but is actually a bit older/different than the released version 2.7 of workbench2.

Actions #36

Updated by Peter Amstutz over 1 year ago

  • Target version changed from Development 2023-09-13 sprint to Development 2023-09-27 sprint
Actions #37

Updated by Peter Amstutz over 1 year ago

  • Target version changed from Development 2023-09-27 sprint to To be scheduled
Actions #38

Updated by Peter Amstutz over 1 year ago

  • Target version changed from To be scheduled to Development 2023-10-11 sprint
Actions #39

Updated by Tom Clegg over 1 year ago

merging changes on wb2 main branch since the initial subtree merge:

18874-merge-wb2 @ 0f5b0542513b572959e39400bae42e69aeb1a7b6 -- developer-run-tests: #3838

  • All agreed upon points are implemented / addressed.
    • There will be more steps after merging this branch.
    • ✅ add Jenkins jobs for testing the version of workbench2 in the arvados repo
    • ▢ (you are here) merge latest main branch of workbench2 into the arvados tree at services/workbench2/ using git-subtree
    • ▢ use the new arvados-server install to rebuild the machine image jenkins uses to run arvados tests (see ENOSPC note above)
    • ▢ run Jenkins jobs manually, fix any other problems that still prevent services/workbench2 tests from passing
    • ▢ configure Jenkins to run the new workbench2 tests as part of the developer-run-tests and run-tests pipelines
    • ▢ update arvbox to use checked-out services/workbench2 instead of arvados-workbench2.git
    • ▢ update debian package-building to use arvados.git/services/workbench2 instead of arvados-workbench2.git
    • ▢ merge latest main branch from arvados-workbench2.git into arvados.git/services/workbench2
    • ▢ prohibit pushing updates to main branch at arvados-workbench2.git (from now on devs will push to arvados.git/services/workbench2 instead)
  • Anything not implemented (discovered or discussed during work) has a follow-up story.
    • I think we can use this ticket to track all the above steps?
  • Code is tested and passing, both automated and manual, what manual testing was done is described
    • The non-workbench2 tests pass, and the workbench2 tests aren't enabled yet because jenkins image isn't suitable yet (see ENOSPC)
  • Documentation has been updated.
    • todo
  • Behaves appropriately at the intended scale (describe intended scale).
    • N/A
  • Considered backwards and forwards compatibility issues between client and server.
    • N/A
  • Follows our coding standards and GUI style guidelines.
Actions #40

Updated by Lucas Di Pentima over 1 year ago

Just one observation:

I think the original idea was to put WB2 inside apps/workbench2 so just commenting this in case it was overlooked.

Other than that, it LGTM

Actions #41

Updated by Tom Clegg over 1 year ago

side note: in order to push the main branch even though it contains old commits that don't satisfy our copyright-header requirements, I temporarily monkeypatched /data/usr-local-arvados-dev/git/hooks/check-copyright-headers.rb on git.arvados.org with the merge commit hash:

 def check_copyright_headers
   if ($newrev[0,6] ==  '000000')
     # A branch is being deleted. Do not check old commits for DCO signoff! 
     all_objects = []
     commits = []
+  elsif $newrev =~ /^df1ebc0e31/
+    # workbench2 subtree merge
+    all_objects = []
+    commits = []
   elsif ($oldrev[0,6] ==  '000000')
Actions #42

Updated by Tom Clegg over 1 year ago

  • Status changed from New to In Progress
Actions #43

Updated by Tom Clegg over 1 year ago

  • Description updated (diff)
Actions #44

Updated by Peter Amstutz over 1 year ago

  • Target version changed from Development 2023-10-11 sprint to Development 2023-10-25 sprint
Actions #45

Updated by Peter Amstutz about 1 year ago

  • Target version changed from Development 2023-10-25 sprint to Development 2023-11-08 sprint
Actions #46

Updated by Tom Clegg about 1 year ago

  • Description updated (diff)
Actions #47

Updated by Peter Amstutz about 1 year ago

  • Target version changed from Development 2023-11-08 sprint to Development 2023-11-29 sprint
Actions #48

Updated by Tom Clegg about 1 year ago

  • Description updated (diff)
Actions #49

Updated by Tom Clegg about 1 year ago

18874-merge-wb2 @ 6ff39245b93dd55e60c7433af64f2244b0091c6e

developer-run-tests-services-workbench2: #23

On jenkins, all tests consistently pass except process.spec.js "displays IO parameters with no value" consistently fails (when setting the token at the beginning of the test).

     AssertionError: object tested must be an array, a map, an object, a set, a string, or a weakset, but undefined given

On my dev machine, all tests consistently pass except process.spec.js "displays IO parameters with keep links and previews" consistently fails (much later in the test, not when setting the token at the beginning). Multiple times in both headless and interactive modes.

Actions #50

Updated by Tom Clegg about 1 year ago

I don't understand it, but this seems to work great:

     cy.visit(`/token/?api_token=${user.token}`);
-    cy.url({ timeout: 10000 }).should("contain", "/projects/");
+    cy.url().should("contain", "/projects/");
     cy.get("div#root").should("contain", "Arvados Workbench (zzzzz)");

developer-run-tests-services-workbench2: #24

developer-run-tests-services-workbench2: #25

Actions #51

Updated by Tom Clegg about 1 year ago

  • Description updated (diff)

18874-merge-wb2 @ f5fd7e2dc13b912e1032a54119f3fb60973f77e2 -- developer-run-tests: #3900

developer-run-tests-services-workbench2: #28

It seems #note-50 did not work great, the next two attempts were just lucky. The next two after that were not lucky, and failed. I increased the timeout to 15s and the next build passed.

Changes:
  • Fix lib/install to pass a real git hash to the wb2 build, if available
  • Fix wb2 integration test script to use the current arvados source tree instead of cloning fresh
  • Fix lib/boot workbench2 script failing in dev/test mode
  • Update cmd/arvados-package to test on debian:11 instead of debian:10
  • wb2 integration tests pass on jenkins (assuming the 15s timeout mentioned above is really enough)
Actions #52

Updated by Lucas Di Pentima about 1 year ago

18874-merge-wb2 LGTM, thanks.

Actions #53

Updated by Tom Clegg about 1 year ago

  • Description updated (diff)
Actions #54

Updated by Tom Clegg about 1 year ago

18874-merge-wb2 @ 5917dffb6d14ec54ff2afa0f2dcc16095609e0dd
  • Add workbench2 to package-building scripts in source:build/ → packages/*/arvados-workbench2_3.0.0~rc0-1_amd64.deb
  • Update scripts to fix a couple of build problems

The new Dockerfiles for debian12 and ubuntu2204 in #20846 (unmerged) will need to have these nodejs/npm changes applied as well. Waiting to see which branch merges first.

I think coordinating this will look like
  1. disable the current workbench2 package-building job in jenkins config
  2. merge this branch
  3. verify the new dev package gets built
  4. update documented release process
Actions #55

Updated by Lucas Di Pentima about 1 year ago

Tom Clegg wrote in #note-54:

18874-merge-wb2 @ 5917dffb6d14ec54ff2afa0f2dcc16095609e0dd
  • Add workbench2 to package-building scripts in source:build/ → packages/*/arvados-workbench2_3.0.0~rc0-1_amd64.deb
  • Update scripts to fix a couple of build problems

I've found just one issue that was fixed with:

diff --git a/build/run-library.sh b/build/run-library.sh
index 3eab0f506..dd878d847 100755
--- a/build/run-library.sh
+++ b/build/run-library.sh
@@ -124,6 +124,7 @@ package_workbench2() {
     local version="$(version_from_git)" 
     cd "$WORKSPACE/$src" 
     rm -rf ./build
+    NODE_ENV=production yarn install
     VERSION="$VERSION" BUILD_NUMBER="$(default_iteration "$pkgname" "$version" yarn)" GIT_COMMIT="$(git rev-parse HEAD | head -c9)" yarn build
     cd "$WORKSPACE/packages/$TARGET" 
     fpm_build "${WORKSPACE}/$src" "${WORKSPACE}/$src/build/=$dst" "$pkgname" dir "$version" \

The rest LGTM, thanks.

Actions #56

Updated by Tom Clegg about 1 year ago

  • Description updated (diff)
Actions #57

Updated by Tom Clegg about 1 year ago

  • Target version changed from Development 2023-11-29 sprint to Development 2024-01-03 sprint
Actions #58

Updated by Peter Amstutz about 1 year ago

  • Target version changed from Development 2024-01-03 sprint to Development 2024-01-17 sprint
Actions #59

Updated by Tom Clegg about 1 year ago

  • Description updated (diff)
Actions #60

Updated by Tom Clegg about 1 year ago

  • Status changed from In Progress to Resolved
  • Description updated (diff)
Actions #61

Updated by Peter Amstutz 9 months ago

  • Release set to 70
Actions

Also available in: Atom PDF