From 1ffe9fa27ee9829c16446a09aa5bd94bcc60ab68 Mon Sep 17 00:00:00 2001 From: Karen Arutyunov Date: Mon, 14 May 2018 21:03:01 +0300 Subject: Add update, clean, and test commands tests --- tests/sync.test | 81 ++++++++++++++++++++++++++++++++++++++++++++++----------- 1 file changed, 66 insertions(+), 15 deletions(-) (limited to 'tests/sync.test') diff --git a/tests/sync.test b/tests/sync.test index 1e044b2..74d9a6d 100644 --- a/tests/sync.test +++ b/tests/sync.test @@ -6,34 +6,37 @@ new += 2>! init += cc "config.cxx=$config.cxx" -d prj 2>! -status += --all --recursive +status += --all --recursive -d prj +deinit += -d prj : dependency : { $clone_prj; - $init -C prj-cfg @cfg &prj/build/bootstrap/*** &prj-cfg/***; - $new -t lib --vcs none libhello &libhello/***; + $init -C @cfg1 &prj-cfg1/***; + $init -C @cfg2 &prj-cfg2/***; + + $new -t lib --vcs none libprj &libprj/***; cat <+prj/repositories.manifest; : role: prerequisite - location: ../libhello + location: ../libprj type: dir EOI cat <+prj/manifest; - depends: libhello + depends: libprj EOI - sed -i -e 's/^(#import .+)$/import libs += libhello%lib{hello}/' \ + sed -i -e 's/^(#import .+)$/import libs += libprj%lib{prj}/' \ prj/prj/buildfile; cat <=prj/prj/prj.cxx; #include - #include + #include using namespace std; @@ -45,22 +48,70 @@ status += --all --recursive return 1; } - hello::say_hello (cout, argv[1]); + prj::say_hello (cout, argv[1]); } EOI + # Sync the default (cfg1) configuration. + # $* 2>>/~"%EOE%"; - fetching dir:$~/libhello \(prerequisite of dir:$~/prj\) + fetching dir:$~/libprj \(prerequisite of dir:$~/prj\) synchronizing: - % new libhello.0\.1\.0-a\.0\..+ \\\(required by prj\\\)% - % upgrade prj.0\.1\.0-a\.0\.19700101000000#1% + % new libprj.+ \\\(required by prj\\\)% + % upgrade prj.+19700101000000#1% EOE - $status -d prj >>~%EOO%; + $status >>~%EOO% 2>>/~"%EOE%"; + in configuration @cfg1: prj configured 0.1.0-a.0.19700101000000#1 - % libhello configured 0\.1\.0-a\.0\..+% + % libprj configured 0.+% + + in configuration @cfg2: + prj configured 0.1.0-a.0.19700101000000 available 0.1.0-a.0.19700101000000#1 EOO + fetching dir:$~/libprj \(prerequisite of dir:$~/prj\) + EOE + + # Sync all configuration. + # + $* --all 2>>~%EOE%; + in configuration @cfg1: + + in configuration @cfg2: + synchronizing: + % new libprj.+ \(required by prj\)% + upgrade prj/0.1.0-a.0.19700101000000#1 + EOE + + $status >>~%EOE%; + in configuration @cfg1: + prj configured 0.1.0-a.0.19700101000000#1 + % libprj configured 0.+% - $build prj/ 2>! &prj/prj/prj$exe &?prj/prj/prj.exe.dlls/***; - prj/prj/prj 'testscript' >'Hello, testscript!' + in configuration @cfg2: + prj configured 0.1.0-a.0.19700101000000#1 + % libprj configured 0.+% + EOE + + # @@ Add synchronizing a single package when 'new -t empty' is supported. + # + $build prj/ 2>>/~"%EOE%"; + %mkdir prj-cfg1/.+%{2} + %.{3} + %ld prj-cfg1/.+%{2} + ln prj-cfg1/prj/prj/exe{prj} -> prj/prj/ + EOE + + $build 'clean:' prj/ 2>>/EOE; + rm prj-cfg1/prj/prj/exe{prj} + rm prj-cfg1/prj/prj/obje{prj} + rm prj-cfg1/prj/fsdir{prj/} + EOE + + $deinit 2>>/"EOE" + deinitializing in project $~/prj/ + synchronizing: + drop prj + drop libprj + EOE } -- cgit v1.1