diff options
author | Peter Melnichenko <mpeterval@gmail.com> | 2016-07-09 16:35:33 +0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-07-09 16:35:33 +0400 |
commit | 8e55688c191827a9b2e9c499a95c888078979e8c (patch) | |
tree | aeaf8c1886c949e8e357b59a04cebc3be3930bce | |
parent | 5af7e0d7c2dcf65e41ae8523f3771e9528be32a7 (diff) | |
parent | a05ba7ce42ae4e42f80b5cacdd8770ae5e6cc04b (diff) | |
download | luarocks-8e55688c191827a9b2e9c499a95c888078979e8c.tar.gz luarocks-8e55688c191827a9b2e9c499a95c888078979e8c.tar.bz2 luarocks-8e55688c191827a9b2e9c499a95c888078979e8c.zip |
Merge pull request #583 from mpeterv/adjust-new-tests
Minor changes and fixes for new test suite
-rw-r--r-- | .busted | 6 | ||||
-rw-r--r-- | .travis.yml | 16 | ||||
-rw-r--r-- | spec/add_spec.lua | 10 | ||||
-rw-r--r-- | spec/build_spec.lua | 7 | ||||
-rw-r--r-- | spec/config_spec.lua | 12 | ||||
-rw-r--r-- | spec/deps_spec.lua | 9 | ||||
-rw-r--r-- | spec/doc_spec.lua | 7 | ||||
-rw-r--r-- | spec/download_spec.lua | 5 | ||||
-rw-r--r-- | spec/fetch_spec.lua | 3 | ||||
-rw-r--r-- | spec/help_spec.lua | 10 | ||||
-rw-r--r-- | spec/install_spec.lua | 22 | ||||
-rw-r--r-- | spec/lint_spec.lua | 10 | ||||
-rw-r--r-- | spec/list_spec.lua | 8 | ||||
-rw-r--r-- | spec/make_manifest_spec.lua | 10 | ||||
-rw-r--r-- | spec/make_spec.lua | 9 | ||||
-rw-r--r-- | spec/new_version_spec.lua | 9 | ||||
-rw-r--r-- | spec/pack_spec.lua | 6 | ||||
-rw-r--r-- | spec/path_spec.lua | 8 | ||||
-rw-r--r-- | spec/purge_spec.lua | 10 | ||||
-rw-r--r-- | spec/refresh_cache_spec.lua | 10 | ||||
-rw-r--r-- | spec/remove_spec.lua | 9 | ||||
-rw-r--r-- | spec/search_spec.lua | 8 | ||||
-rw-r--r-- | spec/show_spec.lua | 8 | ||||
-rw-r--r-- | spec/unpack_spec.lua | 13 | ||||
-rw-r--r-- | spec/upload_spec.lua | 6 | ||||
-rw-r--r-- | spec/util_spec.lua | 10 | ||||
-rw-r--r-- | spec/write_rockspec_spec.lua | 9 | ||||
-rw-r--r-- | test/test_environment.lua | 624 |
28 files changed, 405 insertions, 469 deletions
diff --git a/.busted b/.busted new file mode 100644 index 00000000..29a8137b --- /dev/null +++ b/.busted | |||
@@ -0,0 +1,6 @@ | |||
1 | return { | ||
2 | default = { | ||
3 | helper = "test/test_environment", | ||
4 | ["auto-insulate"] = false | ||
5 | } | ||
6 | } | ||
diff --git a/.travis.yml b/.travis.yml index c8755e7f..02bdb6c9 100644 --- a/.travis.yml +++ b/.travis.yml | |||
@@ -40,11 +40,7 @@ matrix: | |||
40 | 40 | ||
41 | 41 | ||
42 | before_install: | 42 | before_install: |
43 | - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew update; fi | 43 | - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew update; brew install python; fi |
44 | - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew install python3; fi | ||
45 | - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then virtualenv venv -p python3; fi | ||
46 | - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then source venv/bin/activate; fi | ||
47 | |||
48 | - pip install hererocks | 44 | - pip install hererocks |
49 | - hererocks lua_install -r^ --$LUA | 45 | - hererocks lua_install -r^ --$LUA |
50 | - export PATH=$PATH:$PWD/lua_install/bin # Add directory with all installed binaries to PATH | 46 | - export PATH=$PATH:$PWD/lua_install/bin # Add directory with all installed binaries to PATH |
@@ -53,17 +49,17 @@ install: | |||
53 | - luarocks install busted | 49 | - luarocks install busted |
54 | - luarocks install luacov | 50 | - luarocks install luacov |
55 | - luarocks install luacov-coveralls | 51 | - luarocks install luacov-coveralls |
56 | 52 | ||
57 | script: | 53 | script: |
58 | - busted -Xhelper travis,$LUA --verbose | 54 | - busted -Xhelper travis --verbose |
59 | - busted -Xhelper travis,$LUA,env=full --verbose | 55 | - busted -Xhelper travis,env=full --verbose |
60 | 56 | ||
61 | after_success: | 57 | after_success: |
62 | - luacov-coveralls -c $TRAVIS_BUILD_DIR/test/luacov.config --exclude $TRAVIS_BUILD_DIR/test/ | 58 | - luacov-coveralls -c $TRAVIS_BUILD_DIR/test/luacov.config --exclude $TRAVIS_BUILD_DIR/test/ |
63 | - $PWD/lua_install/bin/luacov -c $TRAVIS_BUILD_DIR/test/luacov.config | 59 | - luacov -c $TRAVIS_BUILD_DIR/test/luacov.config |
64 | - grep "Summary" -B1 -A1000 $TRAVIS_BUILD_DIR/test/luacov.report.out | 60 | - grep "Summary" -B1 -A1000 $TRAVIS_BUILD_DIR/test/luacov.report.out |
65 | 61 | ||
66 | notifications: | 62 | notifications: |
67 | email: | 63 | email: |
68 | on_success: change | 64 | on_success: change |
69 | on_failure: change \ No newline at end of file | 65 | on_failure: change |
diff --git a/spec/add_spec.lua b/spec/add_spec.lua index e417f974..dca6f850 100644 --- a/spec/add_spec.lua +++ b/spec/add_spec.lua | |||
@@ -1,20 +1,18 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | local testing_paths = test_env.testing_paths | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local add = require("luarocks.add") | ||
6 | 6 | ||
7 | local extra_rocks = { | 7 | local extra_rocks = { |
8 | "/luasocket-3.0rc1-1.src.rock", | 8 | "/luasocket-3.0rc1-1.src.rock", |
9 | "/luasocket-3.0rc1-1.rockspec" | 9 | "/luasocket-3.0rc1-1.rockspec" |
10 | } | 10 | } |
11 | 11 | ||
12 | expose("LuaRocks add tests #blackbox #b_add", function() | 12 | describe("LuaRocks add tests #blackbox #b_add", function() |
13 | 13 | ||
14 | before_each(function() | 14 | before_each(function() |
15 | test_env.setup_specs(extra_rocks) | 15 | test_env.setup_specs(extra_rocks) |
16 | testing_paths = test_env.testing_paths | ||
17 | run = test_env.run | ||
18 | end) | 16 | end) |
19 | 17 | ||
20 | describe("LuaRocks-admin add tests", function() | 18 | describe("LuaRocks-admin add tests", function() |
@@ -43,4 +41,4 @@ expose("LuaRocks add tests #blackbox #b_add", function() | |||
43 | assert.is_false(run.luarocks_admin_bool("--server=\"localhost@/tmp/luarocks_testing\" add " .. testing_paths.testing_server .. "luasocket-3.0rc1-1.src.rock")) | 41 | assert.is_false(run.luarocks_admin_bool("--server=\"localhost@/tmp/luarocks_testing\" add " .. testing_paths.testing_server .. "luasocket-3.0rc1-1.src.rock")) |
44 | end) | 42 | end) |
45 | end) | 43 | end) |
46 | end) \ No newline at end of file | 44 | end) |
diff --git a/spec/build_spec.lua b/spec/build_spec.lua index 6665de0b..1ce99089 100644 --- a/spec/build_spec.lua +++ b/spec/build_spec.lua | |||
@@ -1,8 +1,9 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
3 | 5 | ||
4 | test_env.unload_luarocks() | 6 | test_env.unload_luarocks() |
5 | local build = require("luarocks.build") | ||
6 | 7 | ||
7 | local extra_rocks = { | 8 | local extra_rocks = { |
8 | "/lmathx-20120430.51-1.src.rock", | 9 | "/lmathx-20120430.51-1.src.rock", |
@@ -26,12 +27,10 @@ local extra_rocks = { | |||
26 | "/validate-args-1.5.4-1.rockspec" | 27 | "/validate-args-1.5.4-1.rockspec" |
27 | } | 28 | } |
28 | 29 | ||
29 | expose("LuaRocks build tests #blackbox #b_build", function() | 30 | describe("LuaRocks build tests #blackbox #b_build", function() |
30 | 31 | ||
31 | before_each(function() | 32 | before_each(function() |
32 | test_env.setup_specs(extra_rocks) | 33 | test_env.setup_specs(extra_rocks) |
33 | testing_paths = test_env.testing_paths | ||
34 | run = test_env.run | ||
35 | end) | 34 | end) |
36 | 35 | ||
37 | describe("LuaRocks build - basic testing set", function() | 36 | describe("LuaRocks build - basic testing set", function() |
diff --git a/spec/config_spec.lua b/spec/config_spec.lua index f6cabd8c..0dee8620 100644 --- a/spec/config_spec.lua +++ b/spec/config_spec.lua | |||
@@ -1,17 +1,17 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
5 | local site_config | ||
3 | 6 | ||
4 | test_env.unload_luarocks() | 7 | test_env.unload_luarocks() |
5 | local cfg = require("luarocks.cfg") | ||
6 | 8 | ||
7 | expose("LuaRocks config tests #blackbox #b_config", function() | 9 | describe("LuaRocks config tests #blackbox #b_config", function() |
8 | 10 | ||
9 | before_each(function() | 11 | before_each(function() |
10 | test_env.setup_specs(extra_rocks) | 12 | test_env.setup_specs() |
11 | test_env.unload_luarocks() -- need to be required here, because site_config is created after first loading of specs | 13 | test_env.unload_luarocks() -- need to be required here, because site_config is created after first loading of specs |
12 | site_config = require("luarocks.site_config") | 14 | site_config = require("luarocks.site_config") |
13 | testing_paths = test_env.testing_paths | ||
14 | run = test_env.run | ||
15 | end) | 15 | end) |
16 | 16 | ||
17 | describe("LuaRocks config - basic tests", function() | 17 | describe("LuaRocks config - basic tests", function() |
@@ -87,4 +87,4 @@ expose("LuaRocks config tests #blackbox #b_config", function() | |||
87 | test_env.remove_dir(testing_paths.testing_lrprefix) | 87 | test_env.remove_dir(testing_paths.testing_lrprefix) |
88 | end) | 88 | end) |
89 | end) | 89 | end) |
90 | end) \ No newline at end of file | 90 | end) |
diff --git a/spec/deps_spec.lua b/spec/deps_spec.lua index ce784080..c1bd404d 100644 --- a/spec/deps_spec.lua +++ b/spec/deps_spec.lua | |||
@@ -1,8 +1,9 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
3 | 5 | ||
4 | test_env.unload_luarocks() | 6 | test_env.unload_luarocks() |
5 | local deps = require("luarocks.deps") | ||
6 | 7 | ||
7 | local extra_rocks = { | 8 | local extra_rocks = { |
8 | "/lxsh-0.8.6-2.src.rock", | 9 | "/lxsh-0.8.6-2.src.rock", |
@@ -12,12 +13,10 @@ local extra_rocks = { | |||
12 | "/lpeg-0.12-1.src.rock" | 13 | "/lpeg-0.12-1.src.rock" |
13 | } | 14 | } |
14 | 15 | ||
15 | expose("LuaRocks deps tests #blackbox #b_deps", function() | 16 | describe("LuaRocks deps tests #blackbox #b_deps", function() |
16 | 17 | ||
17 | before_each(function() | 18 | before_each(function() |
18 | test_env.setup_specs(extra_rocks) | 19 | test_env.setup_specs(extra_rocks) |
19 | testing_paths = test_env.testing_paths | ||
20 | run = test_env.run | ||
21 | end) | 20 | end) |
22 | 21 | ||
23 | it("LuaRocks deps mode one", function() | 22 | it("LuaRocks deps mode one", function() |
@@ -112,4 +111,4 @@ expose("LuaRocks deps tests #blackbox #b_deps", function() | |||
112 | assert.is.falsy(lfs.attributes(testing_paths.testing_tree .. "/lib/luarocks/rocks/lxsh")) | 111 | assert.is.falsy(lfs.attributes(testing_paths.testing_tree .. "/lib/luarocks/rocks/lxsh")) |
113 | assert.is.truthy(lfs.attributes(testing_paths.testing_sys_tree .. "/lib/luarocks/rocks/lxsh")) | 112 | assert.is.truthy(lfs.attributes(testing_paths.testing_sys_tree .. "/lib/luarocks/rocks/lxsh")) |
114 | end) | 113 | end) |
115 | end) \ No newline at end of file | 114 | end) |
diff --git a/spec/doc_spec.lua b/spec/doc_spec.lua index 476b8ea8..9dbeaab8 100644 --- a/spec/doc_spec.lua +++ b/spec/doc_spec.lua | |||
@@ -1,19 +1,16 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local doc = require("luarocks.doc") | ||
6 | 5 | ||
7 | local extra_rocks = { | 6 | local extra_rocks = { |
8 | "/luarepl-0.4-1.src.rock" | 7 | "/luarepl-0.4-1.src.rock" |
9 | } | 8 | } |
10 | 9 | ||
11 | expose("LuaRocks doc tests #blackbox #b_doc", function() | 10 | describe("LuaRocks doc tests #blackbox #b_doc", function() |
12 | 11 | ||
13 | before_each(function() | 12 | before_each(function() |
14 | test_env.setup_specs(extra_rocks) | 13 | test_env.setup_specs(extra_rocks) |
15 | testing_paths = test_env.testing_paths | ||
16 | run = test_env.run | ||
17 | end) | 14 | end) |
18 | 15 | ||
19 | describe("LuaRocks doc basic tests", function() | 16 | describe("LuaRocks doc basic tests", function() |
diff --git a/spec/download_spec.lua b/spec/download_spec.lua index 9b5d9e2e..320d9304 100644 --- a/spec/download_spec.lua +++ b/spec/download_spec.lua | |||
@@ -1,18 +1,17 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local download = require("luarocks.download") | ||
6 | 6 | ||
7 | local extra_rocks = { | 7 | local extra_rocks = { |
8 | "/validate-args-1.5.4-1.rockspec" | 8 | "/validate-args-1.5.4-1.rockspec" |
9 | } | 9 | } |
10 | 10 | ||
11 | expose("LuaRocks download tests #blackbox #b_download", function() | 11 | describe("LuaRocks download tests #blackbox #b_download", function() |
12 | 12 | ||
13 | before_each(function() | 13 | before_each(function() |
14 | test_env.setup_specs(extra_rocks) | 14 | test_env.setup_specs(extra_rocks) |
15 | run = test_env.run | ||
16 | end) | 15 | end) |
17 | 16 | ||
18 | it("LuaRocks download with no flags/arguments", function() | 17 | it("LuaRocks download with no flags/arguments", function() |
diff --git a/spec/fetch_spec.lua b/spec/fetch_spec.lua index 1f298733..05a709e4 100644 --- a/spec/fetch_spec.lua +++ b/spec/fetch_spec.lua | |||
@@ -1,5 +1,4 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | ||
3 | 2 | ||
4 | test_env.unload_luarocks() | 3 | test_env.unload_luarocks() |
5 | local fetch = require("luarocks.fetch") | 4 | local fetch = require("luarocks.fetch") |
@@ -13,4 +12,4 @@ describe("Luarocks fetch test #whitebox #w_fetch", function() | |||
13 | assert.are.same("parser.moon", fetch.url_to_base_dir("git://github.com/Cirru/parser.moon")) | 12 | assert.are.same("parser.moon", fetch.url_to_base_dir("git://github.com/Cirru/parser.moon")) |
14 | assert.are.same("v0.3", fetch.url_to_base_dir("https://github.com/hishamhm/lua-compat-5.2/archive/v0.3")) | 13 | assert.are.same("v0.3", fetch.url_to_base_dir("https://github.com/hishamhm/lua-compat-5.2/archive/v0.3")) |
15 | end) | 14 | end) |
16 | end) \ No newline at end of file | 15 | end) |
diff --git a/spec/help_spec.lua b/spec/help_spec.lua index 0f40dd38..0d41e2e9 100644 --- a/spec/help_spec.lua +++ b/spec/help_spec.lua | |||
@@ -1,14 +1,12 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local help = require("luarocks.help") | ||
6 | 5 | ||
7 | expose("LuaRocks help tests #blackbox #b_help", function() | 6 | describe("LuaRocks help tests #blackbox #b_help", function() |
8 | 7 | ||
9 | before_each(function() | 8 | before_each(function() |
10 | test_env.setup_specs(extra_rocks) | 9 | test_env.setup_specs() |
11 | run = test_env.run | ||
12 | end) | 10 | end) |
13 | 11 | ||
14 | it("LuaRocks help with no flags/arguments", function() | 12 | it("LuaRocks help with no flags/arguments", function() |
@@ -26,4 +24,4 @@ expose("LuaRocks help tests #blackbox #b_help", function() | |||
26 | it("LuaRocks-admin help with no flags/arguments", function() | 24 | it("LuaRocks-admin help with no flags/arguments", function() |
27 | assert.is_true(run.luarocks_admin_bool("help")) | 25 | assert.is_true(run.luarocks_admin_bool("help")) |
28 | end) | 26 | end) |
29 | end) \ No newline at end of file | 27 | end) |
diff --git a/spec/install_spec.lua b/spec/install_spec.lua index 306bbbc1..0e406e22 100644 --- a/spec/install_spec.lua +++ b/spec/install_spec.lua | |||
@@ -1,8 +1,10 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
5 | local env_variables = test_env.env_variables | ||
3 | 6 | ||
4 | test_env.unload_luarocks() | 7 | test_env.unload_luarocks() |
5 | local install = require("luarocks.install") | ||
6 | 8 | ||
7 | local extra_rocks = { | 9 | local extra_rocks = { |
8 | "/cprint-0.1-2.src.rock", | 10 | "/cprint-0.1-2.src.rock", |
@@ -19,14 +21,10 @@ local extra_rocks = { | |||
19 | "/wsapi-1.6-1.src.rock" | 21 | "/wsapi-1.6-1.src.rock" |
20 | } | 22 | } |
21 | 23 | ||
22 | expose("LuaRocks install tests #blackbox #b_install", function() | 24 | describe("LuaRocks install tests #blackbox #b_install", function() |
23 | 25 | ||
24 | before_each(function() | 26 | before_each(function() |
25 | test_env.setup_specs(extra_rocks) | 27 | test_env.setup_specs(extra_rocks) |
26 | testing_paths = test_env.testing_paths | ||
27 | env_variables = test_env.env_variables | ||
28 | run = test_env.run | ||
29 | platform = test_env.platform | ||
30 | end) | 28 | end) |
31 | 29 | ||
32 | describe("LuaRocks install - basic tests", function() | 30 | describe("LuaRocks install - basic tests", function() |
@@ -86,21 +84,21 @@ expose("LuaRocks install tests #blackbox #b_install", function() | |||
86 | 84 | ||
87 | it("LuaRocks install only-deps of luasocket packed rock", function() | 85 | it("LuaRocks install only-deps of luasocket packed rock", function() |
88 | assert.is_true(test_env.need_luasocket()) | 86 | assert.is_true(test_env.need_luasocket()) |
89 | local output = run.luarocks("install --only-deps " .. testing_paths.testing_cache .. "/luasocket-3.0rc1-1." .. platform .. ".rock") | 87 | local output = run.luarocks("install --only-deps " .. testing_paths.testing_cache .. "/luasocket-3.0rc1-1." .. test_env.platform .. ".rock") |
90 | assert.are.same(output, "Successfully installed dependencies for luasocket 3.0rc1-1") | 88 | assert.are.same(output, "Successfully installed dependencies for luasocket 3.0rc1-1") |
91 | end) | 89 | end) |
92 | 90 | ||
93 | it("LuaRocks install binary rock of cprint", function() | 91 | it("LuaRocks install binary rock of cprint", function() |
94 | assert.is_true(test_env.need_luasocket()) | 92 | assert.is_true(test_env.need_luasocket()) |
95 | assert.is_true(run.luarocks_bool("build --pack-binary-rock cprint")) | 93 | assert.is_true(run.luarocks_bool("build --pack-binary-rock cprint")) |
96 | assert.is_true(run.luarocks_bool("install cprint-0.1-2." .. platform .. ".rock")) | 94 | assert.is_true(run.luarocks_bool("install cprint-0.1-2." .. test_env.platform .. ".rock")) |
97 | assert.is_true(os.remove("cprint-0.1-2." .. platform .. ".rock")) | 95 | assert.is_true(os.remove("cprint-0.1-2." .. test_env.platform .. ".rock")) |
98 | end) | 96 | end) |
99 | 97 | ||
100 | it("LuaRocks install reinstall", function() | 98 | it("LuaRocks install reinstall", function() |
101 | assert.is_true(test_env.need_luasocket()) | 99 | assert.is_true(test_env.need_luasocket()) |
102 | assert.is_true(run.luarocks_bool("install " .. testing_paths.testing_cache .. "/luasocket-3.0rc1-1." .. platform .. ".rock")) | 100 | assert.is_true(run.luarocks_bool("install " .. testing_paths.testing_cache .. "/luasocket-3.0rc1-1." .. test_env.platform .. ".rock")) |
103 | assert.is_true(run.luarocks_bool("install --deps-mode=none " .. testing_paths.testing_cache .. "/luasocket-3.0rc1-1." .. platform .. ".rock")) | 101 | assert.is_true(run.luarocks_bool("install --deps-mode=none " .. testing_paths.testing_cache .. "/luasocket-3.0rc1-1." .. test_env.platform .. ".rock")) |
104 | end) | 102 | end) |
105 | end) | 103 | end) |
106 | 104 | ||
@@ -127,4 +125,4 @@ expose("LuaRocks install tests #blackbox #b_install", function() | |||
127 | assert.is.truthy(lfs.attributes(testing_paths.testing_sys_tree .. "/lib/luarocks/rocks/say/1.0-1")) | 125 | assert.is.truthy(lfs.attributes(testing_paths.testing_sys_tree .. "/lib/luarocks/rocks/say/1.0-1")) |
128 | end) | 126 | end) |
129 | end) | 127 | end) |
130 | end) \ No newline at end of file | 128 | end) |
diff --git a/spec/lint_spec.lua b/spec/lint_spec.lua index cba80a3e..f7496037 100644 --- a/spec/lint_spec.lua +++ b/spec/lint_spec.lua | |||
@@ -1,19 +1,17 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | local testing_paths = test_env.testing_paths | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local lint = require("luarocks.lint") | ||
6 | 6 | ||
7 | local extra_rocks = { | 7 | local extra_rocks = { |
8 | "/validate-args-1.5.4-1.rockspec" | 8 | "/validate-args-1.5.4-1.rockspec" |
9 | } | 9 | } |
10 | 10 | ||
11 | expose("LuaRocks lint tests #blackbox #b_lint", function() | 11 | describe("LuaRocks lint tests #blackbox #b_lint", function() |
12 | 12 | ||
13 | before_each(function() | 13 | before_each(function() |
14 | test_env.setup_specs(extra_rocks) | 14 | test_env.setup_specs(extra_rocks) |
15 | testing_paths = test_env.testing_paths | ||
16 | run = test_env.run | ||
17 | end) | 15 | end) |
18 | 16 | ||
19 | it("LuaRocks lint with no flags/arguments", function() | 17 | it("LuaRocks lint with no flags/arguments", function() |
@@ -48,4 +46,4 @@ expose("LuaRocks lint tests #blackbox #b_lint", function() | |||
48 | assert.is_false(run.luarocks_bool("lint " .. testing_paths.testing_dir .. "/testfiles/no_build_table-1.0-1.rockspec")) | 46 | assert.is_false(run.luarocks_bool("lint " .. testing_paths.testing_dir .. "/testfiles/no_build_table-1.0-1.rockspec")) |
49 | end) | 47 | end) |
50 | end) | 48 | end) |
51 | end) \ No newline at end of file | 49 | end) |
diff --git a/spec/list_spec.lua b/spec/list_spec.lua index 545483df..1b082ab6 100644 --- a/spec/list_spec.lua +++ b/spec/list_spec.lua | |||
@@ -1,20 +1,18 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | local testing_paths = test_env.testing_paths | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local list = require("luarocks.list") | ||
6 | 6 | ||
7 | local extra_rocks = { | 7 | local extra_rocks = { |
8 | "/say-1.0-1.src.rock", | 8 | "/say-1.0-1.src.rock", |
9 | "/say-1.2-1.src.rock" | 9 | "/say-1.2-1.src.rock" |
10 | } | 10 | } |
11 | 11 | ||
12 | expose("LuaRocks list tests #blackbox #b_list", function() | 12 | describe("LuaRocks list tests #blackbox #b_list", function() |
13 | 13 | ||
14 | before_each(function() | 14 | before_each(function() |
15 | test_env.setup_specs(extra_rocks) | 15 | test_env.setup_specs(extra_rocks) |
16 | run = test_env.run | ||
17 | testing_paths = test_env.testing_paths | ||
18 | end) | 16 | end) |
19 | 17 | ||
20 | it("LuaRocks list with no flags/arguments", function() | 18 | it("LuaRocks list with no flags/arguments", function() |
diff --git a/spec/make_manifest_spec.lua b/spec/make_manifest_spec.lua index c6cb1328..1c7f5bf8 100644 --- a/spec/make_manifest_spec.lua +++ b/spec/make_manifest_spec.lua | |||
@@ -1,14 +1,12 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local make_manifest = require("luarocks.make_manifest") | ||
6 | 5 | ||
7 | expose("LuaRocks make_manifest tests #blackbox #b_make_manifest", function() | 6 | describe("LuaRocks make_manifest tests #blackbox #b_make_manifest", function() |
8 | 7 | ||
9 | before_each(function() | 8 | before_each(function() |
10 | test_env.setup_specs(extra_rocks) | 9 | test_env.setup_specs() |
11 | run = test_env.run | ||
12 | end) | 10 | end) |
13 | 11 | ||
14 | describe("LuaRocks-admin make manifest tests", function() | 12 | describe("LuaRocks-admin make manifest tests", function() |
@@ -16,4 +14,4 @@ expose("LuaRocks make_manifest tests #blackbox #b_make_manifest", function() | |||
16 | assert.is_true(run.luarocks_admin_bool("make_manifest")) | 14 | assert.is_true(run.luarocks_admin_bool("make_manifest")) |
17 | end) | 15 | end) |
18 | end) | 16 | end) |
19 | end) \ No newline at end of file | 17 | end) |
diff --git a/spec/make_spec.lua b/spec/make_spec.lua index f70bb7e9..2821c143 100644 --- a/spec/make_spec.lua +++ b/spec/make_spec.lua | |||
@@ -1,8 +1,9 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
3 | 5 | ||
4 | test_env.unload_luarocks() | 6 | test_env.unload_luarocks() |
5 | local make = require("luarocks.make") | ||
6 | 7 | ||
7 | local extra_rocks = { | 8 | local extra_rocks = { |
8 | "/lpeg-0.12-1.src.rock", | 9 | "/lpeg-0.12-1.src.rock", |
@@ -12,12 +13,10 @@ local extra_rocks = { | |||
12 | "/lxsh-0.8.6-2.rockspec" | 13 | "/lxsh-0.8.6-2.rockspec" |
13 | } | 14 | } |
14 | 15 | ||
15 | expose("LuaRocks make tests #blackbox #b_make", function() | 16 | describe("LuaRocks make tests #blackbox #b_make", function() |
16 | 17 | ||
17 | before_each(function() | 18 | before_each(function() |
18 | test_env.setup_specs(extra_rocks) | 19 | test_env.setup_specs(extra_rocks) |
19 | run = test_env.run | ||
20 | testing_paths = test_env.testing_paths | ||
21 | end) | 20 | end) |
22 | 21 | ||
23 | it("LuaRocks make with no flags/arguments", function() | 22 | it("LuaRocks make with no flags/arguments", function() |
@@ -96,4 +95,4 @@ expose("LuaRocks make tests #blackbox #b_make", function() | |||
96 | assert.is.truthy(lfs.attributes("lxsh-0.8.6-2.all.rock")) | 95 | assert.is.truthy(lfs.attributes("lxsh-0.8.6-2.all.rock")) |
97 | end) | 96 | end) |
98 | end) | 97 | end) |
99 | end) \ No newline at end of file | 98 | end) |
diff --git a/spec/new_version_spec.lua b/spec/new_version_spec.lua index 57014226..2274bce3 100644 --- a/spec/new_version_spec.lua +++ b/spec/new_version_spec.lua | |||
@@ -1,19 +1,18 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
3 | 5 | ||
4 | test_env.unload_luarocks() | 6 | test_env.unload_luarocks() |
5 | local new_version = require("luarocks.new_version") | ||
6 | 7 | ||
7 | local extra_rocks = { | 8 | local extra_rocks = { |
8 | "/abelhas-1.0-1.rockspec" | 9 | "/abelhas-1.0-1.rockspec" |
9 | } | 10 | } |
10 | 11 | ||
11 | expose("LuaRocks new_version tests #blackbox #b_new_version", function() | 12 | describe("LuaRocks new_version tests #blackbox #b_new_version", function() |
12 | 13 | ||
13 | before_each(function() | 14 | before_each(function() |
14 | test_env.setup_specs(extra_rocks) | 15 | test_env.setup_specs(extra_rocks) |
15 | testing_paths = test_env.testing_paths | ||
16 | run = test_env.run | ||
17 | end) | 16 | end) |
18 | 17 | ||
19 | describe("LuaRocks new_version basic tests", function() | 18 | describe("LuaRocks new_version basic tests", function() |
@@ -50,4 +49,4 @@ expose("LuaRocks new_version tests #blackbox #b_new_version", function() | |||
50 | test_env.remove_files(lfs.currentdir(), "luacov--") | 49 | test_env.remove_files(lfs.currentdir(), "luacov--") |
51 | end) | 50 | end) |
52 | end) | 51 | end) |
53 | end) \ No newline at end of file | 52 | end) |
diff --git a/spec/pack_spec.lua b/spec/pack_spec.lua index a07e7ed2..416184a8 100644 --- a/spec/pack_spec.lua +++ b/spec/pack_spec.lua | |||
@@ -1,8 +1,8 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local pack = require("luarocks.pack") | ||
6 | 6 | ||
7 | local extra_rocks = { | 7 | local extra_rocks = { |
8 | "/luasec-0.6-1.rockspec", | 8 | "/luasec-0.6-1.rockspec", |
@@ -10,12 +10,10 @@ local extra_rocks = { | |||
10 | "/luasocket-3.0rc1-1.rockspec" | 10 | "/luasocket-3.0rc1-1.rockspec" |
11 | } | 11 | } |
12 | 12 | ||
13 | expose("LuaRocks pack tests #blackbox #b_pack", function() | 13 | describe("LuaRocks pack tests #blackbox #b_pack", function() |
14 | 14 | ||
15 | before_each(function() | 15 | before_each(function() |
16 | test_env.setup_specs(extra_rocks) | 16 | test_env.setup_specs(extra_rocks) |
17 | testing_paths = test_env.testing_paths | ||
18 | run = test_env.run | ||
19 | end) | 17 | end) |
20 | 18 | ||
21 | it("LuaRocks pack basic", function() | 19 | it("LuaRocks pack basic", function() |
diff --git a/spec/path_spec.lua b/spec/path_spec.lua index 266ada89..22f07591 100644 --- a/spec/path_spec.lua +++ b/spec/path_spec.lua | |||
@@ -1,13 +1,11 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local path = require("luarocks.path") | ||
6 | 5 | ||
7 | expose("LuaRocks path tests #blackbox #b_path", function() | 6 | describe("LuaRocks path tests #blackbox #b_path", function() |
8 | before_each(function() | 7 | before_each(function() |
9 | test_env.setup_specs(extra_rocks) | 8 | test_env.setup_specs() |
10 | run = test_env.run | ||
11 | end) | 9 | end) |
12 | 10 | ||
13 | it("LuaRocks path bin", function() | 11 | it("LuaRocks path bin", function() |
diff --git a/spec/purge_spec.lua b/spec/purge_spec.lua index 639f96f3..09a9d433 100644 --- a/spec/purge_spec.lua +++ b/spec/purge_spec.lua | |||
@@ -1,14 +1,12 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | local testing_paths = test_env.testing_paths | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local purge = require("luarocks.purge") | ||
6 | 6 | ||
7 | expose("LuaRocks purge tests #blackbox #b_purge", function() | 7 | describe("LuaRocks purge tests #blackbox #b_purge", function() |
8 | before_each(function() | 8 | before_each(function() |
9 | test_env.setup_specs(extra_rocks) | 9 | test_env.setup_specs() |
10 | testing_paths = test_env.testing_paths | ||
11 | run = test_env.run | ||
12 | end) | 10 | end) |
13 | 11 | ||
14 | describe("LuaRocks purge basic tests", function() | 12 | describe("LuaRocks purge basic tests", function() |
diff --git a/spec/refresh_cache_spec.lua b/spec/refresh_cache_spec.lua index 27a95e5c..c20771ab 100644 --- a/spec/refresh_cache_spec.lua +++ b/spec/refresh_cache_spec.lua | |||
@@ -1,14 +1,12 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local refresh_cache = require("luarocks.refresh_cache") | ||
6 | 5 | ||
7 | expose("LuaRocks refresh_cache tests #blackbox #b_refresh_cache", function() | 6 | describe("LuaRocks refresh_cache tests #blackbox #b_refresh_cache", function() |
8 | 7 | ||
9 | before_each(function() | 8 | before_each(function() |
10 | test_env.setup_specs(extra_rocks) | 9 | test_env.setup_specs() |
11 | run = test_env.run | ||
12 | end) | 10 | end) |
13 | 11 | ||
14 | describe("LuaRocks-admin refresh cache tests #ssh", function() | 12 | describe("LuaRocks-admin refresh cache tests #ssh", function() |
@@ -16,4 +14,4 @@ expose("LuaRocks refresh_cache tests #blackbox #b_refresh_cache", function() | |||
16 | assert.is_true(run.luarocks_admin_bool("--server=testing refresh_cache")) | 14 | assert.is_true(run.luarocks_admin_bool("--server=testing refresh_cache")) |
17 | end) | 15 | end) |
18 | end) | 16 | end) |
19 | end) \ No newline at end of file | 17 | end) |
diff --git a/spec/remove_spec.lua b/spec/remove_spec.lua index a94673a8..41c6348a 100644 --- a/spec/remove_spec.lua +++ b/spec/remove_spec.lua | |||
@@ -1,8 +1,9 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
3 | 5 | ||
4 | test_env.unload_luarocks() | 6 | test_env.unload_luarocks() |
5 | local remove = require("luarocks.remove") | ||
6 | 7 | ||
7 | local extra_rocks = { | 8 | local extra_rocks = { |
8 | "/abelhas-1.0-1.rockspec", | 9 | "/abelhas-1.0-1.rockspec", |
@@ -11,12 +12,10 @@ local extra_rocks = { | |||
11 | "/luasocket-3.0rc1-1.rockspec" | 12 | "/luasocket-3.0rc1-1.rockspec" |
12 | } | 13 | } |
13 | 14 | ||
14 | expose("LuaRocks remove tests #blackbox #b_remove", function() | 15 | describe("LuaRocks remove tests #blackbox #b_remove", function() |
15 | 16 | ||
16 | before_each(function() | 17 | before_each(function() |
17 | test_env.setup_specs(extra_rocks) | 18 | test_env.setup_specs(extra_rocks) |
18 | testing_paths = test_env.testing_paths | ||
19 | run = test_env.run | ||
20 | end) | 19 | end) |
21 | 20 | ||
22 | describe("LuaRocks remove basic tests", function() | 21 | describe("LuaRocks remove basic tests", function() |
@@ -82,4 +81,4 @@ expose("LuaRocks remove tests #blackbox #b_remove", function() | |||
82 | it("LuaRocks-admin remove missing", function() | 81 | it("LuaRocks-admin remove missing", function() |
83 | assert.is_false(run.luarocks_admin_bool("--server=testing remove")) | 82 | assert.is_false(run.luarocks_admin_bool("--server=testing remove")) |
84 | end) | 83 | end) |
85 | end) \ No newline at end of file | 84 | end) |
diff --git a/spec/search_spec.lua b/spec/search_spec.lua index a0258942..33c49856 100644 --- a/spec/search_spec.lua +++ b/spec/search_spec.lua | |||
@@ -1,18 +1,16 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local search = require("luarocks.search") | ||
6 | 5 | ||
7 | local extra_rocks = { | 6 | local extra_rocks = { |
8 | "/lzlib-0.4.1.53-1.src.rock" | 7 | "/lzlib-0.4.1.53-1.src.rock" |
9 | } | 8 | } |
10 | 9 | ||
11 | expose("LuaRocks search tests #blackbox #b_search", function() | 10 | describe("LuaRocks search tests #blackbox #b_search", function() |
12 | 11 | ||
13 | before_each(function() | 12 | before_each(function() |
14 | test_env.setup_specs(extra_rocks) | 13 | test_env.setup_specs(extra_rocks) |
15 | run = test_env.run | ||
16 | end) | 14 | end) |
17 | 15 | ||
18 | it("LuaRocks search with no flags/arguments", function() | 16 | it("LuaRocks search with no flags/arguments", function() |
@@ -39,4 +37,4 @@ expose("LuaRocks search tests #blackbox #b_search", function() | |||
39 | local num = 123 | 37 | local num = 123 |
40 | assert.is_true(run.luarocks_bool("search " .. num)) | 38 | assert.is_true(run.luarocks_bool("search " .. num)) |
41 | end) | 39 | end) |
42 | end) \ No newline at end of file | 40 | end) |
diff --git a/spec/show_spec.lua b/spec/show_spec.lua index 85797eb6..f528a6de 100644 --- a/spec/show_spec.lua +++ b/spec/show_spec.lua | |||
@@ -1,14 +1,12 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local show = require("luarocks.show") | ||
6 | 5 | ||
7 | expose("LuaRocks show tests #blackbox #b_show", function() | 6 | describe("LuaRocks show tests #blackbox #b_show", function() |
8 | 7 | ||
9 | before_each(function() | 8 | before_each(function() |
10 | test_env.setup_specs(extra_rocks) | 9 | test_env.setup_specs() |
11 | run = test_env.run | ||
12 | end) | 10 | end) |
13 | 11 | ||
14 | it("LuaRocks show with no flags/arguments", function() | 12 | it("LuaRocks show with no flags/arguments", function() |
diff --git a/spec/unpack_spec.lua b/spec/unpack_spec.lua index efe902f5..76e9e5a8 100644 --- a/spec/unpack_spec.lua +++ b/spec/unpack_spec.lua | |||
@@ -1,21 +1,18 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | local testing_paths = test_env.testing_paths | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local unpack = require("luarocks.unpack") | ||
6 | 6 | ||
7 | local extra_rocks = { | 7 | local extra_rocks = { |
8 | "/cprint-0.1-2.src.rock", | 8 | "/cprint-0.1-2.src.rock", |
9 | "/cprint-0.1-2.rockspec" | 9 | "/cprint-0.1-2.rockspec" |
10 | } | 10 | } |
11 | 11 | ||
12 | expose("LuaRocks unpack tests #blackbox #b_unpack", function() | 12 | describe("LuaRocks unpack tests #blackbox #b_unpack", function() |
13 | 13 | ||
14 | before_each(function() | 14 | before_each(function() |
15 | test_env.setup_specs(extra_rocks) | 15 | test_env.setup_specs(extra_rocks) |
16 | testing_paths = test_env.testing_paths | ||
17 | run = test_env.run | ||
18 | platform = test_env.platform | ||
19 | end) | 16 | end) |
20 | 17 | ||
21 | describe("LuaRocks unpack basic fail tests", function() | 18 | describe("LuaRocks unpack basic fail tests", function() |
@@ -51,9 +48,9 @@ expose("LuaRocks unpack tests #blackbox #b_unpack", function() | |||
51 | it("LuaRocks unpack binary", function() | 48 | it("LuaRocks unpack binary", function() |
52 | assert.is_true(run.luarocks_bool("build cprint")) | 49 | assert.is_true(run.luarocks_bool("build cprint")) |
53 | assert.is_true(run.luarocks_bool("pack cprint")) | 50 | assert.is_true(run.luarocks_bool("pack cprint")) |
54 | assert.is_true(run.luarocks_bool("unpack cprint-0.1-2." .. platform .. ".rock")) | 51 | assert.is_true(run.luarocks_bool("unpack cprint-0.1-2." .. test_env.platform .. ".rock")) |
55 | test_env.remove_dir("cprint-0.1-2") | 52 | test_env.remove_dir("cprint-0.1-2") |
56 | os.remove("cprint-0.1-2." .. platform .. ".rock") | 53 | os.remove("cprint-0.1-2." .. test_env.platform .. ".rock") |
57 | end) | 54 | end) |
58 | end) | 55 | end) |
59 | end) | 56 | end) |
diff --git a/spec/upload_spec.lua b/spec/upload_spec.lua index daf40d61..c10ef0e9 100644 --- a/spec/upload_spec.lua +++ b/spec/upload_spec.lua | |||
@@ -1,18 +1,16 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local run = test_env.run |
3 | 3 | ||
4 | test_env.unload_luarocks() | 4 | test_env.unload_luarocks() |
5 | local upload = require("luarocks.upload") | ||
6 | 5 | ||
7 | local extra_rocks = { | 6 | local extra_rocks = { |
8 | "/lua-cjson-2.1.0-1.src.rock" | 7 | "/lua-cjson-2.1.0-1.src.rock" |
9 | } | 8 | } |
10 | 9 | ||
11 | expose("LuaRocks upload tests #blackbox #b_upload", function() | 10 | describe("LuaRocks upload tests #blackbox #b_upload", function() |
12 | 11 | ||
13 | before_each(function() | 12 | before_each(function() |
14 | test_env.setup_specs(extra_rocks) | 13 | test_env.setup_specs(extra_rocks) |
15 | run = test_env.run | ||
16 | end) | 14 | end) |
17 | 15 | ||
18 | it("LuaRocks upload with no flags/arguments", function() | 16 | it("LuaRocks upload with no flags/arguments", function() |
diff --git a/spec/util_spec.lua b/spec/util_spec.lua index 7c22d1cb..9118ffc9 100644 --- a/spec/util_spec.lua +++ b/spec/util_spec.lua | |||
@@ -1,13 +1,13 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
4 | local testing_paths = test_env.testing_paths | ||
5 | local env_variables = test_env.env_variables | ||
3 | 6 | ||
4 | expose("Basic tests #blackbox #b_util", function() | 7 | describe("Basic tests #blackbox #b_util", function() |
5 | 8 | ||
6 | before_each(function() | 9 | before_each(function() |
7 | test_env.setup_specs(extra_rocks) | 10 | test_env.setup_specs() |
8 | testing_paths = test_env.testing_paths | ||
9 | env_variables = test_env.env_variables | ||
10 | run = test_env.run | ||
11 | end) | 11 | end) |
12 | 12 | ||
13 | it("LuaRocks version", function() | 13 | it("LuaRocks version", function() |
diff --git a/spec/write_rockspec_spec.lua b/spec/write_rockspec_spec.lua index d6e32f15..85e345d5 100644 --- a/spec/write_rockspec_spec.lua +++ b/spec/write_rockspec_spec.lua | |||
@@ -1,14 +1,13 @@ | |||
1 | local test_env = require("test/test_environment") | 1 | local test_env = require("test/test_environment") |
2 | local lfs = require("lfs") | 2 | local lfs = require("lfs") |
3 | local run = test_env.run | ||
3 | 4 | ||
4 | test_env.unload_luarocks() | 5 | test_env.unload_luarocks() |
5 | local write_rockspec = require("luarocks.write_rockspec") | ||
6 | 6 | ||
7 | expose("LuaRocks write_rockspec tests #blackbox #b_write_rockspec", function() | 7 | describe("LuaRocks write_rockspec tests #blackbox #b_write_rockspec", function() |
8 | 8 | ||
9 | before_each(function() | 9 | before_each(function() |
10 | test_env.setup_specs(extra_rocks) | 10 | test_env.setup_specs() |
11 | run = test_env.run | ||
12 | end) | 11 | end) |
13 | 12 | ||
14 | describe("LuaRocks write_rockspec basic tests", function() | 13 | describe("LuaRocks write_rockspec basic tests", function() |
@@ -71,4 +70,4 @@ expose("LuaRocks write_rockspec tests #blackbox #b_write_rockspec", function() | |||
71 | assert.is_true(os.remove("luafcgi-scm-1.rockspec")) | 70 | assert.is_true(os.remove("luafcgi-scm-1.rockspec")) |
72 | end) | 71 | end) |
73 | end) | 72 | end) |
74 | end) \ No newline at end of file | 73 | end) |
diff --git a/test/test_environment.lua b/test/test_environment.lua index 6de501fb..6de7a4e2 100644 --- a/test/test_environment.lua +++ b/test/test_environment.lua | |||
@@ -1,26 +1,38 @@ | |||
1 | local lfs = require("lfs") | 1 | local lfs = require("lfs") |
2 | local test_env = {} | 2 | local test_env = {} |
3 | local arg = arg or { ... } | 3 | |
4 | local help_message = [[ | ||
5 | LuaRocks test-suite | ||
6 | |||
7 | INFORMATION | ||
8 | New test-suite for LuaRocks project, using unit testing framework Busted. | ||
9 | REQUIREMENTS | ||
10 | Be sure sshd is running on your system, or use '--exclude-tags=ssh', | ||
11 | to not execute tests which require sshd. | ||
12 | USAGE | ||
13 | busted [-Xhelper <arguments>] | ||
14 | ARGUMENTS | ||
15 | env=<type> Set type of environment to use ("minimal" or "full", | ||
16 | default: "minimal"). | ||
17 | clean Remove existing testing environment. | ||
18 | travis Add if running on TravisCI. | ||
19 | os=<type> Set OS ("linux", "osx", or "windows"). | ||
20 | ]] | ||
4 | 21 | ||
5 | local function help() | 22 | local function help() |
6 | print("LuaRocks test-suite\n\n".. | 23 | print(help_message) |
7 | [[ | 24 | os.exit(1) |
8 | INFORMATION | 25 | end |
9 | New test-suite for LuaRocks project, using unit testing framework Busted. | 26 | |
10 | REQUIREMENTS | 27 | local function title(str) |
11 | Tests require to have Lua installed and added to PATH. Be sure sshd is runnig on your system, or | 28 | print() |
12 | use '--exclude-tags=ssh', to not execute tests which require sshd. | 29 | print(("-"):rep(#str)) |
13 | USAGE -Xhelper <arguments> | 30 | print(str) |
14 | lua=<version> (mandatory) type your full version of Lua (e.g. --lua 5.2.4) | 31 | print(("-"):rep(#str)) |
15 | OR | 32 | end |
16 | luajit=<version> (mandatory) type your full version of LuaJIT (e.g. --luajit 2.0.3) | 33 | |
17 | 34 | local function exists(path) | |
18 | env=<type> (default:"minimal") type what kind of environment to use ["minimal", "full"] | 35 | return lfs.attributes(path, "mode") ~= nil |
19 | clean remove existing testing environment | ||
20 | travis add just if running on TravisCI | ||
21 | os=<version> type your OS ["linux", "osx", "windows"] | ||
22 | ]]); | ||
23 | os.exit(1) | ||
24 | end | 36 | end |
25 | 37 | ||
26 | --- Helper function for execute_bool and execute_output | 38 | --- Helper function for execute_bool and execute_output |
@@ -70,54 +82,38 @@ local function execute_output(command, print_command, env_variables) | |||
70 | return output:gsub("\n","") -- output adding new line, need to be removed | 82 | return output:gsub("\n","") -- output adding new line, need to be removed |
71 | end | 83 | end |
72 | 84 | ||
73 | --- Set all arguments from input into global variables | 85 | --- Set test_env.LUA_V or test_env.LUAJIT_V based |
74 | function test_env.set_args() | 86 | -- on version of Lua used to run this script. |
75 | if arg[1] == nil then | 87 | function test_env.set_lua_version() |
76 | help() | 88 | if _G.jit then |
77 | end | 89 | test_env.LUAJIT_V = _G.jit.version:match("(2%.%d)%.%d") |
78 | 90 | else | |
79 | local args_position | 91 | test_env.LUA_V = _VERSION:match("5%.%d") |
80 | |||
81 | for i=1, #arg do | ||
82 | if arg[i]:find("-Xhelper") and arg[i+1]:find("lua=") and not arg[i+1]:find("luajit=") then | ||
83 | args_position = i+1 | ||
84 | test_env.LUA_V = arg[args_position]:gsub("(.*)lua=([^%,]+)(.*)","%2") | ||
85 | break | ||
86 | elseif arg[i]:find("-Xhelper") and not arg[i+1]:find("lua=") and arg[i+1]:find("luajit=") then | ||
87 | args_position = i+1 | ||
88 | test_env.LUAJIT_V = arg[args_position]:gsub("(.*)luajit=([^%,]+)(.*)","%2") | ||
89 | break | ||
90 | elseif arg[i]:find("-Xhelper") and arg[i+1]:find("lua=") and arg[i+1]:find("luajit=") then | ||
91 | print("Please specify just Lua or LuaJIT version for testing in format 'lua=X.X.X' or 'luajit=X.X.X', for -Xhelper flag") | ||
92 | os.exit(1) | ||
93 | elseif arg[i]:find("-Xhelper") and not arg[i+1]:find("lua=") and not arg[i+1]:find("luajit=") then | ||
94 | print("Please add mandatory argument - version of Lua or LuaJIT in format 'lua=X.X.X' or 'luajit=X.X.X', for -Xhelper flag") | ||
95 | os.exit(1) | ||
96 | end | ||
97 | end | ||
98 | |||
99 | if not args_position then | ||
100 | help() | ||
101 | end | 92 | end |
93 | end | ||
102 | 94 | ||
95 | --- Set all arguments from input into global variables | ||
96 | function test_env.set_args() | ||
103 | -- if at least Lua/LuaJIT version argument was found on input start to parse other arguments to env. variables | 97 | -- if at least Lua/LuaJIT version argument was found on input start to parse other arguments to env. variables |
104 | test_env.TYPE_TEST_ENV = "minimal" | 98 | test_env.TYPE_TEST_ENV = "minimal" |
105 | 99 | ||
106 | if arg[args_position]:find("env=") then | 100 | for _, argument in ipairs(arg) do |
107 | test_env.TYPE_TEST_ENV = arg[args_position]:gsub("(.*)env=([^%,]+)(.*)","%2") | 101 | if argument:find("^env=") then |
108 | end | 102 | test_env.TYPE_TEST_ENV = argument:match("^env=(.*)$") |
109 | if arg[args_position]:find("clean") then | 103 | elseif argument == "clean" then |
110 | test_env.TEST_ENV_CLEAN = true | 104 | test_env.TEST_ENV_CLEAN = true |
111 | end | 105 | elseif argument == "travis" then |
112 | if arg[args_position]:find("travis") then | 106 | test_env.TRAVIS = true |
113 | test_env.TRAVIS = true | 107 | elseif argument:find("^os=") then |
114 | end | 108 | test_env.TEST_TARGET_OS = argument:match("^os=(.*)$") |
115 | if arg[args_position]:find("os=") then | 109 | else |
116 | test_env.TEST_TARGET_OS = arg[args_position]:gsub("(.*)os=([^%,]+)(.*)","%2") | 110 | help() |
111 | end | ||
117 | end | 112 | end |
118 | 113 | ||
119 | if not test_env.TEST_TARGET_OS then | 114 | if not test_env.TEST_TARGET_OS then |
120 | print("[OS CHECK]") | 115 | title("OS CHECK") |
116 | |||
121 | if execute_bool("sw_vers") then | 117 | if execute_bool("sw_vers") then |
122 | test_env.TEST_TARGET_OS = "osx" | 118 | test_env.TEST_TARGET_OS = "osx" |
123 | elseif execute_bool("uname -s") then | 119 | elseif execute_bool("uname -s") then |
@@ -125,7 +121,6 @@ function test_env.set_args() | |||
125 | else | 121 | else |
126 | test_env.TEST_TARGET_OS = "windows" | 122 | test_env.TEST_TARGET_OS = "windows" |
127 | end | 123 | end |
128 | print("--------------") | ||
129 | end | 124 | end |
130 | return true | 125 | return true |
131 | end | 126 | end |
@@ -133,15 +128,13 @@ end | |||
133 | --- Remove directory recursively | 128 | --- Remove directory recursively |
134 | -- @param path string: directory path to delete | 129 | -- @param path string: directory path to delete |
135 | function test_env.remove_dir(path) | 130 | function test_env.remove_dir(path) |
136 | if lfs.attributes(path) then | 131 | if exists(path) then |
137 | for file in lfs.dir(path) do | 132 | for file in lfs.dir(path) do |
138 | if file ~= "." and file ~= ".." then | 133 | if file ~= "." and file ~= ".." then |
139 | local full_path = path..'/'..file | 134 | local full_path = path..'/'..file |
140 | local attr = lfs.attributes(full_path) | ||
141 | 135 | ||
142 | if attr.mode == "directory" then | 136 | if lfs.attributes(full_path, "mode") == "directory" then |
143 | test_env.remove_dir(full_path) | 137 | test_env.remove_dir(full_path) |
144 | os.remove(full_path) | ||
145 | else | 138 | else |
146 | os.remove(full_path) | 139 | os.remove(full_path) |
147 | end | 140 | end |
@@ -151,32 +144,30 @@ function test_env.remove_dir(path) | |||
151 | os.remove(path) | 144 | os.remove(path) |
152 | end | 145 | end |
153 | 146 | ||
154 | --- Remove directory recursively | 147 | --- Remove subdirectories of a directory that match a pattern |
155 | -- @param path string: directory path to delete | 148 | -- @param path string: path to directory |
156 | -- @param pattern string: pattern in directories | 149 | -- @param pattern string: pattern matching basenames of subdirectories to be removed |
157 | function test_env.remove_dir_pattern(path, pattern) | 150 | function test_env.remove_subdirs(path, pattern) |
158 | if lfs.attributes(path) then | 151 | if exists(path) then |
159 | for file in lfs.dir(path) do | 152 | for file in lfs.dir(path) do |
160 | if file ~= "." and file ~= ".." then | 153 | if file ~= "." and file ~= ".." then |
161 | local full_path = path..'/'..file | 154 | local full_path = path..'/'..file |
162 | local attr = lfs.attributes(full_path) | ||
163 | 155 | ||
164 | if attr.mode == "directory" and file:find(pattern) then | 156 | if lfs.attributes(full_path, "mode") == "directory" and file:find(pattern) then |
165 | test_env.remove_dir(full_path) | 157 | test_env.remove_dir(full_path) |
166 | os.remove(full_path) | ||
167 | end | 158 | end |
168 | end | 159 | end |
169 | end | 160 | end |
170 | end | 161 | end |
171 | end | 162 | end |
172 | 163 | ||
173 | --- Remove files based on filename | 164 | --- Remove files matching a pattern |
174 | -- @param path string: directory where to delete files | 165 | -- @param path string: directory where to delete files |
175 | -- @param pattern string: pattern in filenames | 166 | -- @param pattern string: pattern matching basenames of files to be deleted |
176 | -- @return result_check boolean: true if one or more files deleted | 167 | -- @return result_check boolean: true if one or more files deleted |
177 | function test_env.remove_files(path, pattern) | 168 | function test_env.remove_files(path, pattern) |
178 | local result_check = false | 169 | local result_check = false |
179 | if lfs.attributes(path) then | 170 | if exists(path) then |
180 | for file in lfs.dir(path) do | 171 | for file in lfs.dir(path) do |
181 | if file ~= "." and file ~= ".." then | 172 | if file ~= "." and file ~= ".." then |
182 | if file:find(pattern) then | 173 | if file:find(pattern) then |
@@ -192,51 +183,44 @@ end | |||
192 | 183 | ||
193 | 184 | ||
194 | --- Function for downloading rocks and rockspecs | 185 | --- Function for downloading rocks and rockspecs |
195 | -- @param rocks table: table with full name of rocks/rockspecs to download | 186 | -- @param urls table: array of full names of rocks/rockspecs to download |
196 | -- @param save_path string: path to directory, where to download rocks/rockspecs | 187 | -- @param save_path string: path to directory, where to download rocks/rockspecs |
197 | -- @return make_manifest boolean: true if new rocks downloaded | 188 | -- @return make_manifest boolean: true if new rocks downloaded |
198 | local function download_rocks(rocks, save_path) | 189 | local function download_rocks(urls, save_path) |
199 | local luarocks_repo = "https://luarocks.org" | 190 | local luarocks_repo = "https://luarocks.org" |
200 | local make_manifest = false | 191 | local make_manifest = false |
201 | 192 | ||
202 | for _,rock in ipairs(rocks) do | 193 | for _, url in ipairs(urls) do |
203 | -- check if already downloaded | 194 | -- check if already downloaded |
204 | if not os.rename( save_path .. rock, save_path .. rock) then | 195 | if not exists(save_path .. url) then |
205 | execute_bool("wget -cP " .. save_path .. " " .. luarocks_repo .. rock) | 196 | execute_bool("wget -cP " .. save_path .. " " .. luarocks_repo .. url) |
206 | make_manifest = true | 197 | make_manifest = true |
207 | end | 198 | end |
208 | end | 199 | end |
209 | return make_manifest | 200 | return make_manifest |
210 | end | 201 | end |
211 | 202 | ||
212 | --- Create config files for testing | 203 | --- Create a file containing a string. |
213 | -- @param config_path string: path where to save config file | 204 | -- @param path string: path to file. |
214 | -- @param config_content string: content of this config file | 205 | -- @param str string: content of the file. |
215 | local function create_config(config_path, config_content) | 206 | local function write_file(path, str) |
216 | local file, err = io.open(config_path, "w+") | 207 | local file = assert(io.open(path, "w")) |
217 | if not file then return nil, err end | 208 | file:write(str) |
218 | file:write(config_content) | ||
219 | file:close() | 209 | file:close() |
220 | end | 210 | end |
221 | 211 | ||
222 | --- Create md5sum of directory structure recursively, based on filename and size | 212 | --- Create md5sum of directory structure recursively, based on filename and size |
223 | -- @param path string: path to directory for generate md5sum | 213 | -- @param path string: path to directory for generate md5sum |
224 | -- @param testing_os string(optional): version of PC OS | ||
225 | -- @return md5sum string: md5sum of directory | 214 | -- @return md5sum string: md5sum of directory |
226 | local function hash_environment(path, testing_os) | 215 | local function hash_environment(path) |
227 | local md5sum = "" | 216 | if test_env.TEST_TARGET_OS == "linux" then |
228 | testing_os = testing_os or test_env.TEST_TARGET_OS | 217 | return execute_output("find " .. path .. " -printf \"%s %p\n\" | md5sum") |
229 | 218 | elseif test_env.TEST_TARGET_OS == "osx" then | |
230 | if testing_os == "linux" then | 219 | return execute_output("find " .. path .. " -type f -exec stat -f \"%z %N\" {} \\; | md5") |
231 | md5sum = execute_output("find " .. path .. " -printf \"%s %p\n\" | md5sum") | 220 | else |
232 | end | 221 | -- TODO: Windows |
233 | if testing_os == "osx" then | 222 | return "" |
234 | md5sum = execute_output("find " .. path .. " -type f -exec stat -f \"%z %N\" {} \\; | md5") | ||
235 | end | 223 | end |
236 | --TODO if testing_os == "windows" then | ||
237 | -- md5sum = execute_output("find . -printf \"%s %p\n\" | md5sum") | ||
238 | -- end | ||
239 | return md5sum | ||
240 | end | 224 | end |
241 | 225 | ||
242 | --- Create environment variables needed for tests | 226 | --- Create environment variables needed for tests |
@@ -275,51 +259,48 @@ local function create_md5sums(testing_paths) | |||
275 | return md5sums | 259 | return md5sums |
276 | end | 260 | end |
277 | 261 | ||
278 | local function run_luarocks(testing_paths, env_variables) | 262 | local function make_run_function(cmd_name, exec_function, with_coverage, do_print) |
279 | 263 | local cmd_prefix = test_env.testing_paths.lua .. " " | |
280 | local function make_command_function(exec_function, lua_cmd, do_print) | 264 | |
281 | return function(cmd, new_vars) | 265 | if with_coverage then |
282 | local temp_vars = {} | 266 | cmd_prefix = cmd_prefix .. "-e \"require('luacov.runner')('" .. test_env.testing_paths.testing_dir .. "/luacov.config')\" " |
283 | for k, v in pairs(env_variables) do | 267 | end |
268 | |||
269 | cmd_prefix = cmd_prefix .. test_env.testing_paths.src_dir .. "/bin/" .. cmd_name .. " " | ||
270 | |||
271 | return function(cmd, new_vars) | ||
272 | local temp_vars = {} | ||
273 | for k, v in pairs(test_env.env_variables) do | ||
274 | temp_vars[k] = v | ||
275 | end | ||
276 | if new_vars then | ||
277 | for k, v in pairs(new_vars) do | ||
284 | temp_vars[k] = v | 278 | temp_vars[k] = v |
285 | end | 279 | end |
286 | if new_vars then | ||
287 | for k, v in pairs(new_vars) do | ||
288 | temp_vars[k] = v | ||
289 | end | ||
290 | end | ||
291 | return exec_function(lua_cmd .. cmd, do_print, temp_vars) | ||
292 | end | 280 | end |
281 | return exec_function(cmd_prefix .. cmd, do_print, temp_vars) | ||
293 | end | 282 | end |
283 | end | ||
294 | 284 | ||
295 | local run = {} | 285 | local function make_run_functions() |
296 | 286 | return { | |
297 | local cov_str = testing_paths.lua .. " -e\"require('luacov.runner')('" .. testing_paths.testing_dir .. "/luacov.config')\" " | 287 | luarocks = make_run_function("luarocks", execute_output, true, true), |
298 | 288 | luarocks_bool = make_run_function("luarocks", execute_bool, true, true), | |
299 | local luarocks_cmd = cov_str .. testing_paths.src_dir .. "/bin/luarocks " | 289 | luarocks_noprint = make_run_function("luarocks", execute_bool, true, false), |
300 | run.luarocks = make_command_function(execute_output, luarocks_cmd, true) | 290 | luarocks_nocov = make_run_function("luarocks", execute_bool, false, true), |
301 | run.luarocks_bool = make_command_function(execute_bool, luarocks_cmd, true) | 291 | luarocks_noprint_nocov = make_run_function("luarocks", execute_bool, false, false), |
302 | run.luarocks_noprint = make_command_function(execute_bool, luarocks_cmd, false) | 292 | luarocks_admin = make_run_function("luarocks-admin", execute_output, true, true), |
303 | 293 | luarocks_admin_bool = make_run_function("luarocks-admin", execute_bool, true, true), | |
304 | local luarocks_nocov_cmd = testing_paths.lua .. " " .. testing_paths.src_dir .. "/bin/luarocks " | 294 | luarocks_admin_nocov = make_run_function("luarocks-admin", execute_bool, false, false) |
305 | run.luarocks_nocov = make_command_function(execute_bool, luarocks_nocov_cmd, true) | 295 | } |
306 | run.luarocks_noprint_nocov = make_command_function(execute_bool, luarocks_nocov_cmd, false) | ||
307 | |||
308 | local luarocks_admin_cmd = cov_str .. testing_paths.src_dir .. "/bin/luarocks-admin " | ||
309 | run.luarocks_admin = make_command_function(execute_output, luarocks_admin_cmd, true) | ||
310 | run.luarocks_admin_bool = make_command_function(execute_bool, luarocks_admin_cmd, true) | ||
311 | |||
312 | local luarocks_admin_nocov_cmd = testing_paths.lua .. " " .. testing_paths.src_dir .. "/bin/luarocks-admin " | ||
313 | run.luarocks_admin_nocov = make_command_function(execute_bool, luarocks_admin_nocov_cmd, false) | ||
314 | |||
315 | return run | ||
316 | end | 296 | end |
317 | 297 | ||
318 | --- Build environment for testing | 298 | --- Rebuild environment. |
319 | local function build_environment(env_rocks, testing_paths, env_variables) | 299 | -- Remove old installed rocks and install new ones, |
320 | print("\n--------------------") | 300 | -- updating manifests and tree copies. |
321 | print("BUILDING ENVIRONMENT") | 301 | local function build_environment(rocks, env_variables) |
322 | print("--------------------") | 302 | title("BUILDING ENVIRONMENT") |
303 | local testing_paths = test_env.testing_paths | ||
323 | test_env.remove_dir(testing_paths.testing_tree) | 304 | test_env.remove_dir(testing_paths.testing_tree) |
324 | test_env.remove_dir(testing_paths.testing_sys_tree) | 305 | test_env.remove_dir(testing_paths.testing_sys_tree) |
325 | test_env.remove_dir(testing_paths.testing_tree_copy) | 306 | test_env.remove_dir(testing_paths.testing_tree_copy) |
@@ -328,14 +309,14 @@ local function build_environment(env_rocks, testing_paths, env_variables) | |||
328 | lfs.mkdir(testing_paths.testing_tree) | 309 | lfs.mkdir(testing_paths.testing_tree) |
329 | lfs.mkdir(testing_paths.testing_sys_tree) | 310 | lfs.mkdir(testing_paths.testing_sys_tree) |
330 | 311 | ||
331 | local run = run_luarocks(testing_paths, env_variables) | 312 | test_env.run.luarocks_admin_nocov("make_manifest " .. testing_paths.testing_server) |
332 | run.luarocks_admin_nocov("make_manifest " .. testing_paths.testing_server) | 313 | test_env.run.luarocks_admin_nocov("make_manifest " .. testing_paths.testing_cache) |
333 | run.luarocks_admin_nocov("make_manifest " .. testing_paths.testing_cache) | ||
334 | 314 | ||
335 | for _,package in ipairs(env_rocks) do | 315 | for _, rock in ipairs(rocks) do |
336 | if not run.luarocks_nocov("install --only-server=" .. testing_paths.testing_cache .. " --tree=" .. testing_paths.testing_sys_tree .. " " .. package, env_variables) then | 316 | if not test_env.run.luarocks_nocov("install --only-server=" .. testing_paths.testing_cache .. " --tree=" .. testing_paths.testing_sys_tree .. " " .. rock, env_variables) then |
337 | run.luarocks_nocov("build --tree=" .. testing_paths.testing_sys_tree .. " " .. package, env_variables) | 317 | test_env.run.luarocks_nocov("build --tree=" .. testing_paths.testing_sys_tree .. " " .. rock, env_variables) |
338 | run.luarocks_nocov("pack --tree=" .. testing_paths.testing_sys_tree .. " " .. package .. "; mv " .. package .. "-*.rock " .. testing_paths.testing_cache, env_variables) | 318 | test_env.run.luarocks_nocov("pack --tree=" .. testing_paths.testing_sys_tree .. " " .. rock, env_variables) |
319 | execute_bool("mv " .. rock .. "-*.rock " .. testing_paths.testing_cache) | ||
339 | end | 320 | end |
340 | end | 321 | end |
341 | 322 | ||
@@ -361,32 +342,11 @@ local function reset_environment(testing_paths, md5sums) | |||
361 | end | 342 | end |
362 | 343 | ||
363 | local function create_paths(luaversion_full) | 344 | local function create_paths(luaversion_full) |
364 | local testing_paths = {} | 345 | local cfg = require("luarocks.cfg") |
365 | |||
366 | testing_paths.luadir = "" | ||
367 | |||
368 | if test_env.TRAVIS then | ||
369 | testing_paths.luadir = lfs.currentdir() .. "/lua_install" | ||
370 | testing_paths.lua = testing_paths.luadir .. "/bin/lua" | ||
371 | end | ||
372 | 346 | ||
373 | if test_env.LUA_V and not test_env.TRAVIS then | 347 | local testing_paths = {} |
374 | if lfs.attributes("/usr/bin/lua") then | 348 | testing_paths.luadir = cfg.variables.LUA_BINDIR:gsub("/bin/?$", "") |
375 | testing_paths.luadir = "/usr" | 349 | testing_paths.lua = cfg.variables.LUA_BINDIR .. "/" .. cfg.lua_interpreter |
376 | testing_paths.lua = testing_paths.luadir .. "/bin/lua" | ||
377 | elseif lfs.attributes("/usr/local/bin/lua") then | ||
378 | testing_paths.luadir = "/usr/local" | ||
379 | testing_paths.lua = testing_paths.luadir .. "/bin/lua" | ||
380 | end | ||
381 | elseif test_env.LUAJIT_V and not test_env.TRAVIS then | ||
382 | if lfs.attributes("/usr/bin/luajit") then | ||
383 | testing_paths.luadir = "/usr" | ||
384 | testing_paths.lua = testing_paths.luadir .. "/bin/luajit" | ||
385 | elseif lfs.attributes("/usr/local/bin/luajit") then | ||
386 | testing_paths.luadir = "/usr/local" | ||
387 | testing_paths.lua = testing_paths.luadir .. "/bin/luajit" | ||
388 | end | ||
389 | end | ||
390 | 350 | ||
391 | testing_paths.luarocks_tmp = "/tmp/luarocks_testing" --windows? | 351 | testing_paths.luarocks_tmp = "/tmp/luarocks_testing" --windows? |
392 | 352 | ||
@@ -415,13 +375,11 @@ function test_env.unload_luarocks() | |||
415 | end | 375 | end |
416 | 376 | ||
417 | --- Function for initially setup of environment, variables, md5sums for spec files | 377 | --- Function for initially setup of environment, variables, md5sums for spec files |
418 | function test_env.setup_specs(extra_rocks, luaversion_full) | 378 | function test_env.setup_specs(extra_rocks) |
419 | -- if global variable about successful creation of testing environment doesn't exists, build environment | 379 | -- if global variable about successful creation of testing environment doesn't exists, build environment |
420 | if not test_env.setup_done then | 380 | if not test_env.setup_done then |
421 | test_env.set_args() | ||
422 | |||
423 | if test_env.TRAVIS then | 381 | if test_env.TRAVIS then |
424 | if not os.rename(os.getenv("HOME") .. "/.ssh/id_rsa.pub", os.getenv("HOME") .. "/.ssh/id_rsa.pub") then | 382 | if not exists(os.getenv("HOME") .. "/.ssh/id_rsa.pub") then |
425 | execute_bool("ssh-keygen -t rsa -P \"\" -f ~/.ssh/id_rsa") | 383 | execute_bool("ssh-keygen -t rsa -P \"\" -f ~/.ssh/id_rsa") |
426 | execute_bool("cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys") | 384 | execute_bool("cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys") |
427 | execute_bool("chmod og-wx ~/.ssh/authorized_keys") | 385 | execute_bool("chmod og-wx ~/.ssh/authorized_keys") |
@@ -429,197 +387,213 @@ function test_env.setup_specs(extra_rocks, luaversion_full) | |||
429 | end | 387 | end |
430 | end | 388 | end |
431 | 389 | ||
432 | luaversion_full = luaversion_full or test_env.LUA_V or test_env.LUAJIT_V | ||
433 | |||
434 | test_env.main() | 390 | test_env.main() |
435 | |||
436 | -- Set paths, env_vars and functions for specs | ||
437 | test_env.testing_paths = create_paths(luaversion_full) | ||
438 | test_env.env_variables = create_env(test_env.testing_paths) | ||
439 | package.path = test_env.env_variables.LUA_PATH | 391 | package.path = test_env.env_variables.LUA_PATH |
440 | 392 | ||
441 | test_env.run = run_luarocks(test_env.testing_paths, test_env.env_variables) | ||
442 | test_env.platform = execute_output(test_env.testing_paths.lua .. " -e 'print(require(\"luarocks.cfg\").arch)'", false, test_env.env_variables) | 393 | test_env.platform = execute_output(test_env.testing_paths.lua .. " -e 'print(require(\"luarocks.cfg\").arch)'", false, test_env.env_variables) |
443 | test_env.md5sums = create_md5sums(test_env.testing_paths) | 394 | test_env.md5sums = create_md5sums(test_env.testing_paths) |
444 | test_env.setup_done = true | 395 | test_env.setup_done = true |
396 | title("RUNNING TESTS") | ||
445 | end | 397 | end |
446 | 398 | ||
447 | if extra_rocks then | 399 | if extra_rocks then |
448 | local make_manifest = download_rocks(extra_rocks, test_env.testing_paths.testing_server) | 400 | local make_manifest = download_rocks(extra_rocks, test_env.testing_paths.testing_server) |
449 | if make_manifest then | 401 | if make_manifest then |
450 | local run = run_luarocks(test_env.testing_paths, test_env.env_variables) | 402 | test_env.run.luarocks_admin_nocov("make_manifest " .. test_env.testing_paths.testing_server) |
451 | run.luarocks_admin_nocov("make_manifest " .. test_env.testing_paths.testing_server) | ||
452 | end | 403 | end |
453 | end | 404 | end |
454 | 405 | ||
455 | reset_environment(test_env.testing_paths, test_env.md5sums, test_env.env_variables) | 406 | reset_environment(test_env.testing_paths, test_env.md5sums, test_env.env_variables) |
456 | |||
457 | return true | ||
458 | end | 407 | end |
459 | 408 | ||
460 | --- Helper function for tests which needs luasocket installed | 409 | --- Helper function for tests which needs luasocket installed |
461 | function test_env.need_luasocket(luarocks_nocov, testing_cache, platform) | 410 | function test_env.need_luasocket() |
462 | luarocks_nocov = luarocks_nocov or test_env.run.luarocks_nocov | 411 | if test_env.run.luarocks_nocov("show luasocket") then |
463 | testing_cache = testing_cache or test_env.testing_paths.testing_cache | ||
464 | platform = platform or test_env.platform | ||
465 | |||
466 | if luarocks_nocov("show luasocket") then | ||
467 | return true | 412 | return true |
468 | else | 413 | else |
469 | testing_cache = testing_cache .. "/" | 414 | local testing_cache = test_env.testing_paths.testing_cache .. "/" |
470 | local luasocket_rock = "luasocket-3.0rc1-1." .. platform .. ".rock" | 415 | local luasocket_rock = "luasocket-3.0rc1-1." .. test_env.platform .. ".rock" |
471 | if not os.rename( testing_cache .. luasocket_rock, testing_cache .. luasocket_rock) then | 416 | if not exists(testing_cache .. luasocket_rock) then |
472 | luarocks_nocov("build --pack-binary-rock luasocket 3.0rc1-1") | 417 | test_env.run.luarocks_nocov("build --pack-binary-rock luasocket 3.0rc1-1") |
473 | os.rename(luasocket_rock, testing_cache .. luasocket_rock) | 418 | os.rename(luasocket_rock, testing_cache .. luasocket_rock) |
474 | end | 419 | end |
475 | luarocks_nocov("install " .. testing_cache .. luasocket_rock) | 420 | return test_env.run.luarocks_nocov("install " .. testing_cache .. luasocket_rock) |
476 | end | 421 | end |
477 | return true | 422 | end |
423 | |||
424 | --- For each key-value pair in replacements table | ||
425 | -- replace %{key} in given string with value. | ||
426 | local function substitute(str, replacements) | ||
427 | return (str:gsub("%%%b{}", function(marker) | ||
428 | return replacements[marker:sub(3, -2)] | ||
429 | end)) | ||
430 | end | ||
431 | |||
432 | |||
433 | --- Create configs for luacov and several versions of Luarocks | ||
434 | -- configs needed for some tests. | ||
435 | local function create_configs() | ||
436 | -- testing_config.lua and testing_config_show_downloads.lua | ||
437 | local config_content = substitute([[ | ||
438 | rocks_trees = { | ||
439 | "%{testing_tree}", | ||
440 | { name = "system", root = "%{testing_sys_tree}" }, | ||
441 | } | ||
442 | rocks_servers = { | ||
443 | "%{testing_server}" | ||
444 | } | ||
445 | local_cache = "%{testing_cache}" | ||
446 | upload_server = "testing" | ||
447 | upload_user = "%{user}" | ||
448 | upload_servers = { | ||
449 | testing = { | ||
450 | rsync = "localhost/tmp/luarocks_testing", | ||
451 | }, | ||
452 | } | ||
453 | external_deps_dirs = { | ||
454 | "/usr/local", | ||
455 | "/usr", | ||
456 | -- These are used for a test that fails, so it | ||
457 | -- can point to invalid paths: | ||
458 | { | ||
459 | prefix = "/opt", | ||
460 | bin = "bin", | ||
461 | include = "include", | ||
462 | lib = { "lib", "lib64" }, | ||
463 | } | ||
464 | } | ||
465 | ]], { | ||
466 | user = os.getenv("USER"), | ||
467 | testing_sys_tree = test_env.testing_paths.testing_sys_tree, | ||
468 | testing_tree = test_env.testing_paths.testing_tree, | ||
469 | testing_server = test_env.testing_paths.testing_server, | ||
470 | testing_cache = test_env.testing_paths.testing_cache | ||
471 | }) | ||
472 | |||
473 | write_file(test_env.testing_paths.testing_dir .. "/testing_config.lua", config_content .. " \nweb_browser = \"true\"") | ||
474 | write_file(test_env.testing_paths.testing_dir .. "/testing_config_show_downloads.lua", config_content | ||
475 | .. "show_downloads = true \n rocks_servers={\"http://luarocks.org/repositories/rocks\"}") | ||
476 | |||
477 | -- testing_config_sftp.lua | ||
478 | config_content = substitute([[ | ||
479 | rocks_trees = { | ||
480 | "%{testing_tree}", | ||
481 | "%{testing_sys_tree}", | ||
482 | } | ||
483 | local_cache = "%{testing_cache}" | ||
484 | upload_server = "testing" | ||
485 | upload_user = "%{user}" | ||
486 | upload_servers = { | ||
487 | testing = { | ||
488 | sftp = "localhost/tmp/luarocks_testing", | ||
489 | }, | ||
490 | } | ||
491 | ]], { | ||
492 | user = os.getenv("USER"), | ||
493 | testing_sys_tree = test_env.testing_paths.testing_sys_tree, | ||
494 | testing_tree = test_env.testing_paths.testing_tree, | ||
495 | testing_cache = test_env.testing_paths.testing_cache | ||
496 | }) | ||
497 | |||
498 | write_file(test_env.testing_paths.testing_dir .. "/testing_config_sftp.lua", config_content) | ||
499 | |||
500 | -- luacov.config | ||
501 | config_content = substitute([[ | ||
502 | return { | ||
503 | statsfile = "%{testing_dir}/luacov.stats.out", | ||
504 | reportfile = "%{testing_dir}/luacov.report.out", | ||
505 | modules = { | ||
506 | ["luarocks"] = "src/bin/luarocks", | ||
507 | ["luarocks-admin"] = "src/bin/luarocks-admin", | ||
508 | ["luarocks.*"] = "src", | ||
509 | ["luarocks.*.*"] = "src", | ||
510 | ["luarocks.*.*.*"] = "src" | ||
511 | } | ||
512 | } | ||
513 | ]], { | ||
514 | testing_dir = test_env.testing_paths.testing_dir | ||
515 | }) | ||
516 | |||
517 | write_file(test_env.testing_paths.testing_dir .. "/luacov.config", config_content) | ||
518 | end | ||
519 | |||
520 | --- Remove testing directories. | ||
521 | local function clean() | ||
522 | print("Cleaning testing directory...") | ||
523 | test_env.remove_dir(test_env.testing_paths.luarocks_tmp) | ||
524 | test_env.remove_subdirs(test_env.testing_paths.testing_dir, "testing[_%-]") | ||
525 | test_env.remove_files(test_env.testing_paths.testing_dir, "testing_") | ||
526 | test_env.remove_files(test_env.testing_paths.testing_dir, "luacov") | ||
527 | print("Cleaning done!") | ||
528 | end | ||
529 | |||
530 | --- Install luarocks into testing prefix. | ||
531 | local function install_luarocks(install_env_vars) | ||
532 | -- Configure LuaRocks testing environment | ||
533 | local configure_cmd = "./configure --with-lua=" .. test_env.testing_paths.luadir .. | ||
534 | " --prefix=" .. test_env.testing_paths.testing_lrprefix .. | ||
535 | " && make clean" | ||
536 | |||
537 | assert(execute_bool(configure_cmd, false, install_env_vars)) | ||
538 | assert(execute_bool("make src/luarocks/site_config.lua && make dev", false, install_env_vars)) | ||
478 | end | 539 | end |
479 | 540 | ||
480 | --- | 541 | --- |
481 | -- Main function to create config files and testing environment | 542 | -- Main function to create config files and testing environment |
482 | function test_env.main(luaversion_full, env_type, env_clean) | 543 | function test_env.main() |
483 | luaversion_full = luaversion_full or test_env.LUA_V or test_env.LUAJIT_V | 544 | local testing_paths = test_env.testing_paths |
484 | local testing_paths = create_paths(luaversion_full) | 545 | |
485 | 546 | if test_env.TEST_ENV_CLEAN then | |
486 | env_clean = env_clean or test_env.TEST_ENV_CLEAN | 547 | clean() |
487 | if env_clean then | ||
488 | print("Cleaning testing directory...") | ||
489 | test_env.remove_dir(testing_paths.luarocks_tmp) | ||
490 | test_env.remove_dir_pattern(testing_paths.testing_dir, "testing_") | ||
491 | test_env.remove_dir_pattern(testing_paths.testing_dir, "testing-") | ||
492 | test_env.remove_files(testing_paths.testing_dir, "testing_") | ||
493 | test_env.remove_files(testing_paths.testing_dir, "luacov") | ||
494 | print("Cleaning done!") | ||
495 | end | 548 | end |
496 | 549 | ||
497 | lfs.mkdir(testing_paths.testing_cache) | 550 | lfs.mkdir(testing_paths.testing_cache) |
498 | lfs.mkdir(testing_paths.luarocks_tmp) | 551 | lfs.mkdir(testing_paths.luarocks_tmp) |
499 | 552 | ||
500 | --- CONFIG FILES | 553 | create_configs() |
501 | -- testing_config.lua and testing_config_show_downloads.lua | ||
502 | local config_content = ([[rocks_trees = { | ||
503 | "%{testing_tree}", | ||
504 | { name = "system", root = "%{testing_sys_tree}" }, | ||
505 | } | ||
506 | rocks_servers = { | ||
507 | "%{testing_server}" | ||
508 | } | ||
509 | local_cache = "%{testing_cache}" | ||
510 | upload_server = "testing" | ||
511 | upload_user = "%{user}" | ||
512 | upload_servers = { | ||
513 | testing = { | ||
514 | rsync = "localhost/tmp/luarocks_testing", | ||
515 | }, | ||
516 | } | ||
517 | external_deps_dirs = { | ||
518 | "/usr/local", | ||
519 | "/usr", | ||
520 | -- These are used for a test that fails, so it | ||
521 | -- can point to invalid paths: | ||
522 | { | ||
523 | prefix = "/opt", | ||
524 | bin = "bin", | ||
525 | include = "include", | ||
526 | lib = { "lib", "lib64" }, | ||
527 | } | ||
528 | }]]):gsub("%%%b{}", { | ||
529 | ["%{user}"] = os.getenv("USER"), | ||
530 | ["%{testing_sys_tree}"] = testing_paths.testing_sys_tree, | ||
531 | ["%{testing_tree}"] = testing_paths.testing_tree, | ||
532 | ["%{testing_server}"] = testing_paths.testing_server, | ||
533 | ["%{testing_cache}"] = testing_paths.testing_cache}) | ||
534 | |||
535 | create_config(testing_paths.testing_dir .. "/testing_config.lua", config_content .. " \nweb_browser = \"true\"") | ||
536 | create_config(testing_paths.testing_dir .. "/testing_config_show_downloads.lua", config_content | ||
537 | .. "show_downloads = true \n rocks_servers={\"http://luarocks.org/repositories/rocks\"}") | ||
538 | 554 | ||
539 | -- testing_config_sftp.lua | 555 | local install_env_vars = { |
540 | config_content=([[rocks_trees = { | 556 | LUAROCKS_CONFIG = test_env.testing_paths.testing_dir .. "/testing_config.lua", |
541 | "%{testing_tree}", | 557 | LUA_PATH = "", |
542 | "%{testing_sys_tree}", | 558 | LUA_CPATH = "" |
543 | } | ||
544 | local_cache = "%{testing_cache}" | ||
545 | upload_server = "testing" | ||
546 | upload_user = "%{user}" | ||
547 | upload_servers = { | ||
548 | testing = { | ||
549 | sftp = "localhost/tmp/luarocks_testing", | ||
550 | }, | ||
551 | }]]):gsub("%%%b{}", { | ||
552 | ["%{user}"] = os.getenv("USER"), | ||
553 | ["%{testing_sys_tree}"] = testing_paths.testing_sys_tree, | ||
554 | ["%{testing_tree}"] = testing_paths.testing_tree, | ||
555 | ["%{testing_cache}"] = testing_paths.testing_cache}) | ||
556 | |||
557 | create_config(testing_paths.testing_dir .. "/testing_config_sftp.lua", config_content) | ||
558 | |||
559 | -- luacov.config | ||
560 | config_content=([[return { | ||
561 | statsfile = "%{testing_dir}/luacov.stats.out", | ||
562 | reportfile = "%{testing_dir}/luacov.report.out", | ||
563 | modules = { | ||
564 | ["luarocks"] = "src/bin/luarocks", | ||
565 | ["luarocks-admin"] = "src/bin/luarocks-admin", | ||
566 | ["luarocks.*"] = "src", | ||
567 | ["luarocks.*.*"] = "src", | ||
568 | ["luarocks.*.*.*"] = "src" | ||
569 | } | 559 | } |
570 | }]]):gsub("%%%b{}", { | ||
571 | ["%{testing_dir}"] = testing_paths.testing_dir}) | ||
572 | |||
573 | create_config(testing_paths.testing_dir .. "/luacov.config", config_content) | ||
574 | 560 | ||
575 | -- Create environment variables for configuration | 561 | install_luarocks(install_env_vars) |
576 | local temp_env_variables = {LUAROCKS_CONFIG = testing_paths.testing_dir .. "/testing_config.lua",LUA_PATH="",LUA_CPATH=""} | ||
577 | |||
578 | -- Configure LuaRocks testing environment | ||
579 | local configure_cmd = "./configure --with-lua=" .. testing_paths.luadir .. " --prefix=" .. testing_paths.testing_lrprefix | ||
580 | configure_cmd = configure_cmd .. " && make clean" | ||
581 | |||
582 | if not execute_bool(configure_cmd, false, temp_env_variables) then | ||
583 | os.exit(1) | ||
584 | end | ||
585 | if not execute_bool("make src/luarocks/site_config.lua && make dev", false, temp_env_variables) then | ||
586 | os.exit(1) | ||
587 | end | ||
588 | 562 | ||
589 | -- Preparation of rocks for building environment | 563 | -- Preparation of rocks for building environment |
590 | env_type = env_type or test_env.TYPE_TEST_ENV | 564 | local rocks = {} -- names of rocks, required for building environment |
591 | 565 | local urls = {} -- names of rock and rockspec files to be downloaded | |
592 | local env_rocks = {} -- short names of rocks, required for building environment | 566 | table.insert(urls, "/luacov-0.11.0-1.rockspec") |
593 | local rocks = {} -- full names of rocks required for download | 567 | table.insert(urls, "/luacov-0.11.0-1.src.rock") |
594 | rocks[#rocks+1] = "/luacov-0.11.0-1.rockspec" | 568 | |
595 | rocks[#rocks+1] = "/luacov-0.11.0-1.src.rock" | 569 | if test_env.TYPE_TEST_ENV == "full" then |
596 | 570 | table.insert(urls, "/luafilesystem-1.6.3-1.src.rock") | |
597 | if env_type == "full" then | 571 | table.insert(urls, "/luasocket-3.0rc1-1.src.rock") |
598 | rocks[#rocks+1] = "/luafilesystem-1.6.3-1.src.rock" | 572 | table.insert(urls, "/luasocket-3.0rc1-1.rockspec") |
599 | rocks[#rocks+1] = "/luasocket-3.0rc1-1.src.rock" | 573 | table.insert(urls, "/luaposix-33.2.1-1.src.rock") |
600 | rocks[#rocks+1] = "/luasocket-3.0rc1-1.rockspec" | 574 | table.insert(urls, "/md5-1.2-1.src.rock") |
601 | rocks[#rocks+1] = "/luaposix-33.2.1-1.src.rock" | 575 | table.insert(urls, "/lzlib-0.4.1.53-1.src.rock") |
602 | rocks[#rocks+1] = "/md5-1.2-1.src.rock" | 576 | rocks = {"luafilesystem", "luasocket", "luaposix", "md5", "lzlib"} |
603 | rocks[#rocks+1] = "/lzlib-0.4.1.53-1.src.rock" | 577 | |
604 | env_rocks = {"luafilesystem", "luasocket", "luaposix", "md5", "lzlib"} | 578 | if test_env.LUA_V ~= "5.1" then |
605 | end | 579 | table.insert(urls, "/luabitop-1.0.2-1.rockspec") |
606 | if env_type == "full" and luaversion_full ~= "5.1.5" then | 580 | table.insert(urls, "/luabitop-1.0.2-1.src.rock") |
607 | rocks[#rocks+1] = "/luabitop-1.0.2-1.rockspec" | 581 | table.insert(rocks, "luabitop") |
608 | rocks[#rocks+1] = "/luabitop-1.0.2-1.src.rock" | 582 | end |
609 | table.insert(env_rocks, "luabitop") | ||
610 | end | 583 | end |
611 | 584 | ||
612 | table.insert(env_rocks, "luacov") -- luacov is needed for minimal or full environment | 585 | table.insert(rocks, "luacov") -- luacov is needed for minimal or full environment |
613 | 586 | ||
614 | -- Download rocks needed for LuaRocks testing environment | 587 | -- Download rocks needed for LuaRocks testing environment |
615 | lfs.mkdir(testing_paths.testing_server) | 588 | lfs.mkdir(testing_paths.testing_server) |
616 | download_rocks(rocks, testing_paths.testing_server) | 589 | download_rocks(urls, testing_paths.testing_server) |
617 | 590 | build_environment(rocks, install_env_vars) | |
618 | build_environment(env_rocks, testing_paths, temp_env_variables) | ||
619 | |||
620 | print("----------------") | ||
621 | print(" RUNNING TESTS") | ||
622 | print("----------------") | ||
623 | end | 591 | end |
624 | 592 | ||
593 | test_env.set_lua_version() | ||
594 | test_env.set_args() | ||
595 | test_env.testing_paths = create_paths(test_env.LUA_V or test_env.LUAJIT_V) | ||
596 | test_env.env_variables = create_env(test_env.testing_paths) | ||
597 | test_env.run = make_run_functions() | ||
598 | |||
625 | return test_env | 599 | return test_env |