diff options
author | Lukas Larsson <[email protected]> | 2012-03-09 11:41:23 +0100 |
---|---|---|
committer | Lukas Larsson <[email protected]> | 2012-03-09 11:41:23 +0100 |
commit | 38972afbf2ad77e299ffbd918d57385bd3cc6cce (patch) | |
tree | 87ec7d5a1b67d1fdb674b466ad192e038cd240e6 | |
parent | 23b971babc42752c1bc0130df3e044ab69a6e43e (diff) | |
parent | 89eda5d5783b7f81e238d8108f3a2e8ac9cbf02e (diff) | |
download | otp-38972afbf2ad77e299ffbd918d57385bd3cc6cce.tar.gz otp-38972afbf2ad77e299ffbd918d57385bd3cc6cce.tar.bz2 otp-38972afbf2ad77e299ffbd918d57385bd3cc6cce.zip |
Merge branch 'maint'
* maint:
Ignore non-app suites when checking suites to skip
Create special spec file when application is missing
-rw-r--r-- | lib/test_server/src/ts.erl | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/lib/test_server/src/ts.erl b/lib/test_server/src/ts.erl index 729a2b11fc..7e48a11f33 100644 --- a/lib/test_server/src/ts.erl +++ b/lib/test_server/src/ts.erl @@ -301,7 +301,15 @@ run(List, Opts) when is_list(List), is_list(Opts) -> run(Testspec, Config) when is_atom(Testspec), is_list(Config) -> Options=check_test_get_opts(Testspec, Config), File=atom_to_list(Testspec), - run_test(File, [{spec,[File++".spec"]}], Options); + Spec = case code:lib_dir(Testspec) of + {error, bad_name} when Testspec /= emulator, + Testspec /= system, + Testspec /= epmd -> + create_skip_spec(Testspec, tests(Testspec)); + _ -> + File++".spec" + end, + run_test(File, [{spec,[Spec]}], Options); %% Runs one module in a spec (interactive) run(Testspec, Mod) when is_atom(Testspec), is_atom(Mod) -> run_test({atom_to_list(Testspec), Mod}, @@ -332,6 +340,21 @@ run(Testspec, Mod, Case, Config) when is_atom(Testspec), Args = [{suite,atom_to_list(Mod)}, {testcase,atom_to_list(Case)}], run_test(atom_to_list(Testspec), Args, Options). +%% Create a spec to skip all SUITES, this is used when the application +%% to be tested is not part of the OTP release to be tested. +create_skip_spec(Testspec, SuitesToSkip) -> + {ok,Cwd} = file:get_cwd(), + TestspecString = atom_to_list(Testspec), + Specname = TestspecString++"_skip.spec", + {ok,D} = file:open(filename:join([filename:dirname(Cwd), + TestspecString++"_test",Specname]), + [write]), + TestDir = "\"../"++TestspecString++"_test\"", + io:format(D,"{suites, "++TestDir++", all}.~n",[]), + io:format(D,"{skip_suites, "++TestDir++", ~w, \"Skipped as application" + " is not in path!\"}.",[SuitesToSkip]), + Specname. + %% Check testspec to be valid and get possible Options %% from the config. check_test_get_opts(Testspec, Config) -> |