Project

General

Profile

Actions

Bug #16589

closed

arv-federation-migrate script issues

Added by Lucas Di Pentima over 4 years ago. Updated over 4 years ago.

Status:
Resolved
Priority:
Normal
Assigned To:
Category:
-
Target version:
Start date:
07/10/2020
Due date:
% Done:

100%

Estimated time:
(Total: 0.00 h)
Story points:
-
Release relationship:
Auto

Description

We've received report of this script having problems with the following:

  • Dry run mode fails because of undefined variable(s)
  • New users are created without first/last names, that makes it difficult to share with
  • Feature request: Could the migrated collections/projects NOT be placed on a special "Migrated from..." subproject?

Subtasks 1 (0 open1 closed)

Task #16591: Review 16589-arv-fed-migrate-fixesResolvedPeter Amstutz07/10/2020

Actions
Actions #1

Updated by Lucas Di Pentima over 4 years ago

Updates at bfdc7fac1 - branch 16589-arv-fed-migrate-fixes
Test run: arv-federation-migrate-test: #80

  • Fixes dry-run mode.
  • Adds command-line argument to avoid migrating data to a special subproject.
  • Makes new user creation take the first & last names of the account being migrated.
  • Adds test checks for first+last names migration.
Actions #2

Updated by Lucas Di Pentima over 4 years ago

Sorry, a debugging import fell through the cracks, removed at aa7332d4c

Actions #3

Updated by Peter Amstutz over 4 years ago

A couple thoughts.

Per feedback the message "Not migrating %s because user is admin but target user %s is not admin on %s" should probably also include the instructions "please ensure the user admin status is the same on both clusters"

I'm thinking instead of a flag "--avoid-subproject-creation" that should just move things to the user as the default. If there is a name collision we should make sure the error clearly says what happened and explains what the admin needs to do about it. We could try to detect name collisions through the API but it would be kind of slow. I don't really want to write that code unless we have to.

Actions #4

Updated by Peter Amstutz over 4 years ago

Here's the error you get if you try to merge a users and there's a collision reassigning ownership:

Error: request failed: http://localhost:8004/arvados/v1/users/merge: 422 Unprocessable Entity: #<ActiveRecord::RecordNotUnique: PG::UniqueViolation: ERROR:  duplicate key value violates unique constraint "index_collections_on_owner_uuid_and_name" 
DETAIL:  Key (owner_uuid, name)=(x20vs-tpzed-hhh7bidyjo43cm6, Collection ABC) already exists.
: UPDATE "collections" SET "owner_uuid" = 'x20vs-tpzed-hhh7bidyjo43cm6' WHERE "collections"."owner_uuid" = $1> (req-16loxhmfybacdpz8tlph)
Actions #5

Updated by Peter Amstutz over 4 years ago

How about doing a regex match on the error message, if we can match on something like:

Key \(owner_uuid, name\)=\((:uuid pattern:), (.*)\) already exists. UPDATE "(.*)"

Then we can provide a more useful error message saying "both source and target have a $2 named $3, please rename them".

Although, that will be annoying if there's more than one collision.

Alternately, if there's a collision, it could rename one of them automatically. Or fallback on creating a group.

If we assume this is unlikely to happen, then the least effort solution would be to simply provide a useful error if it does happen.

Actions #6

Updated by Lucas Di Pentima over 4 years ago

From chat: We will make the migrate script to attempt migrating data to the target's home project and if there's an error, do a regex-match to see if the problem is about name collisions. If it is, give a meaningful error message to the admin and provide a command line flag to make the migrate script to fallback to migrate into a subproject.

Actions #7

Updated by Lucas Di Pentima over 4 years ago

Updates at 5147b5515
Test run: arv-federation-migrate-test: #84

  • Changes the default behaviour to migrate user's data directly to the target account's home project instead of a new subproject.
  • Provides a command line flag --data-into-subproject that allows the admin to fallback to the previous behaviour if needed.
  • Detects naming collision errors and explains why the user account can't be migrated, offering the previously mentioned flag as a way of solving the problem.
  • Expands the explanation message when source & target accounts differ in their admin status, noting that a federated admin user has admin powers on the entire federation.
Actions #8

Updated by Peter Amstutz over 4 years ago

Let's tweak this message slightly:

(%s) Target owner %s already has a %s named '%s', skipping. Please rename it or use --data-into-subproject to migrate all users' data into a special subproject." % (email, target_owner, rsc_type[:-1], rsc_name))

->

(%s) Cannot migrate to %s because both origin and target users have a %s named '%s'. Please rename the conflicting items or use --data-into-subproject to migrate all users' data into a special subproject." % (email, target_owner, rsc_type[:-1], rsc_name))

Rest LGTM!

Actions #9

Updated by Lucas Di Pentima over 4 years ago

Updates at 81c2dc65f

  • Updates error message as requested on note-8.

Manual test proof:

(venv-arvados) lucas@buster:~/arvados$ arv-federation-migrate --migrate users.csv
Checking that the federation is well connected
Getting user list from x1stu
Getting user list from x2b3l
Getting user list from x3vnm
(test12@example.com) Migrating x3vnm-tpzed-cxi6su8x5yw3lc3 to x2b3l-tpzed-7kw5oe4pum34b74 on x3vnm
(test12@example.com) Cannot migrate to x2b3l-tpzed-7kw5oe4pum34b74 because both origin and target users have a group named 'New project'. Please rename the conflicting items or use --data-into-subproject to migrate all users' data into a special subproject.
Actions #10

Updated by Anonymous over 4 years ago

  • Status changed from In Progress to Resolved
  • % Done changed from 0 to 100
Actions #11

Updated by Ward Vandewege over 4 years ago

  • Release changed from 34 to 25
Actions #12

Updated by Peter Amstutz over 4 years ago

  • Release changed from 25 to 34
Actions

Also available in: Atom PDF