diff options
author | Karen Arutyunov <karen@codesynthesis.com> | 2018-03-06 23:52:11 +0300 |
---|---|---|
committer | Karen Arutyunov <karen@codesynthesis.com> | 2018-03-08 13:35:44 +0300 |
commit | 7e4b2dcd0e5ddd37276879e699fd84059183f5e2 (patch) | |
tree | c6edcaf646a28f7a993b348401c2f330d99cba10 /tests/pkg-unpack.test | |
parent | ccd8c8dadfcfd9181772b3061e7b075d88942505 (diff) |
Add support for dir repository
Diffstat (limited to 'tests/pkg-unpack.test')
-rw-r--r-- | tests/pkg-unpack.test | 74 |
1 files changed, 67 insertions, 7 deletions
diff --git a/tests/pkg-unpack.test b/tests/pkg-unpack.test index e4f07d4..af07fc5 100644 --- a/tests/pkg-unpack.test +++ b/tests/pkg-unpack.test @@ -47,8 +47,8 @@ rep_fetch += -d cfg --auth all 2>! : replace-with-existing : $clone_cfg; -$* -r 2>>EOE != 0 - error: --replace|-r can only be specified with --existing|-e +$* foo -r 2>>EOE != 0 + error: --replace|-r can only be specified with external package EOE : no-dir @@ -98,7 +98,7 @@ $* 2>>EOE != 0 EOE $pkg_purge libfoo 2>'purged libfoo/1.0.0'; - $* -e $src/libfoo-1.1.0 2>'unpacked libfoo/1.1.0'; + $* -e $src/libfoo-1.1.0 2>'using libfoo/1.1.0 (external)'; $pkg_status libfoo/1.1.0 1>'unpacked; available'; $pkg_purge libfoo 2>'purged libfoo/1.1.0' @@ -115,7 +115,7 @@ $* 2>>EOE != 0 info: use 'pkg-unpack --replace|-r' to replace EOE - $* -r -e $src/libfoo-1.1.0 2>'unpacked libfoo/1.1.0'; + $* -r -e $src/libfoo-1.1.0 2>'using libfoo/1.1.0 (external)'; $pkg_status libfoo/1.1.0 1>'unpacked; available'; $pkg_purge libfoo 2>'purged libfoo/1.1.0' @@ -134,7 +134,7 @@ $* 2>>EOE != 0 info: use 'pkg-unpack --replace|-r' to replace EOE - $* -r -e $src/libfoo-1.1.0 2>'unpacked libfoo/1.1.0'; + $* -r -e $src/libfoo-1.1.0 2>'using libfoo/1.1.0 (external)'; $pkg_status libfoo/1.1.0 1>'unpacked; available'; $pkg_purge libfoo 2>'purged libfoo/1.1.0' @@ -149,7 +149,7 @@ $* 2>>EOE != 0 error: package libfoo does not exist in configuration cfg/ EOE - $* -e $src/libfoo-1.1.0 2>'unpacked libfoo/1.1.0'; + $* -e $src/libfoo-1.1.0 2>'using libfoo/1.1.0 (external)'; $* libfoo 2>>EOE != 0; error: package libfoo is unpacked @@ -177,7 +177,7 @@ $* 2>>EOE != 0 $clone_cfg; cp --no-cleanup -r $src/libfoo-1.1.0 ./; - $* -p -e libfoo-1.1.0 2>'unpacked libfoo/1.1.0'; + $* -p -e libfoo-1.1.0 2>'using libfoo/1.1.0 (external)'; $pkg_purge libfoo 2>'purged libfoo/1.1.0' } @@ -194,3 +194,63 @@ $* 2>>EOE != 0 $pkg_purge libhello 2>'purged libhello/1.0.0' } + +: dir-rep +: +{ + rep_add += --type dir + + : no-repos + : + { + $clone_root_cfg; + + $* libfoo/1.1.0 2>>/EOE != 0 + error: configuration cfg/ has no repositories + info: use 'bpkg rep-add' to add a repository + EOE + } + + : unfetched + : + { + $clone_root_cfg && $rep_add $src/libfoo-1.1.0; + + $* libfoo/1.1.0 2>>/EOE != 0 + error: configuration cfg/ has no available packages + info: use 'bpkg rep-fetch' to fetch available packages list + EOE + } + + : unavailable + : + { + $clone_root_cfg && $rep_add $src/libfoo-1.1.0 && $rep_fetch; + + $* libfoo/1.0.0 2>>EOE != 0 + error: package libfoo 1.0.0 is not available + EOE + } + + : unavailable-dir-based + : + { + $clone_root_cfg && $rep_add $rep/t1 --type pkg && $rep_fetch --trust-yes; + + $* libfoo/1.0.0 2>>EOE != 0 + error: package libfoo 1.0.0 is not available from a directory-based repository + EOE + } + + : available + : + { + $clone_root_cfg && $rep_add $src/libfoo-1.1.0 && $rep_fetch; + + $* libfoo/1.1.0 2>>EOE; + using libfoo/1.1.0 (external) + EOE + + $pkg_status libfoo 1>'unpacked 1.1.0; available sys:?' + } +} |