diff options
author | Florian Pritz <bluewind@xinu.at> | 2014-10-06 21:24:04 +0200 |
---|---|---|
committer | Florian Pritz <bluewind@xinu.at> | 2015-05-27 15:46:05 +0200 |
commit | 517e420a8a7a2222c3fba25a049cbed694d74ae9 (patch) | |
tree | 35c7a6c85ccf12b0d3a3dafa4a092e6a5b80b7c9 /db-move | |
parent | aa4db02702313cf277b2c56b51ea9eb916de9468 (diff) | |
download | dbscripts-517e420a8a7a2222c3fba25a049cbed694d74ae9.tar.gz dbscripts-517e420a8a7a2222c3fba25a049cbed694d74ae9.tar.xz |
make test.d/db-move.sh pass
Signed-off-by: Florian Pritz <bluewind@xinu.at>
Diffstat (limited to 'db-move')
-rwxr-xr-x | db-move | 41 |
1 files changed, 27 insertions, 14 deletions
@@ -20,33 +20,46 @@ if ! check_repo_permission $repo_to || ! check_repo_permission $repo_from; then die "You don't have permission to move packages from ${repo_from} to ${repo_to}" fi -# TODO: this might lock too much (architectures) -for pkgarch in ${ARCHES[@]}; do +if ! in_array "$arch" "${ARCHES[@]}" "all"; then + die "Invalid arch '$arch'" +fi + +if [[ $arch == "all" ]]; then + arches=(${ARCHES[@]}) +else + arches=($arch) +fi + +for pkgarch in ${arches[@]}; do repo_lock ${repo_to} ${pkgarch} || exit 1 repo_lock ${repo_from} ${pkgarch} || exit 1 done msg "Moving packages from [${repo_from}] to [${repo_to}]..." -for pkgname in "${pkgnames[@]}"; do - pkgentry=$(pkgentry_from_db "$repo_from" "$arch" "$pkgname") - pkgs=($(getpkgfiles "$ftppath_from$arch/$pkgentry"*${PKGEXT})) +for arch in ${arches[@]}; do + for pkgname in "${pkgnames[@]}"; do + msg2 "$arch $pkgname" + + pkgentry=$(pkgentry_from_db "$repo_from" "$arch" "$pkgname") + pkgs=($(getpkgfiles "$ftppath_from$arch/$pkgentry"*${PKGEXT})) - if [[ -z $pkgentry ]]; then - warning "Failed to detect pkgentry for $pkgname" - continue - fi + if [[ -z $pkgentry ]]; then + warning "Failed to detect pkgentry for $pkgname" + continue + fi - for pkg in "${pkgs[@]}"; do - pkgname=$(getpkgname "$pkg") - arch_db_add "${repo_to}" "$arch" "${pkg##*/}" - arch_db_remove "${repo_from}" "$arch" "$pkgname" + for pkg in "${pkgs[@]}"; do + pkgname=$(getpkgname "$pkg") + arch_db_add "${repo_to}" "$arch" "${pkg##*/}" + arch_db_remove "${repo_from}" "$arch" "$pkgname" + done done done arch_history_commit "db-move: $repo_from -> $repo_to: ${pkgnames[@]}" -for pkgarch in ${ARCHES[@]}; do +for pkgarch in ${arches[@]}; do repo_unlock ${repo_from} ${pkgarch} repo_unlock ${repo_to} ${pkgarch} done |