%% %% %CopyrightBegin% %% %% Copyright Ericsson AB 2009-2016. All Rights Reserved. %% %% Licensed under the Apache License, Version 2.0 (the "License"); %% you may not use this file except in compliance with the License. %% You may obtain a copy of the License at %% %% http://www.apache.org/licenses/LICENSE-2.0 %% %% Unless required by applicable law or agreed to in writing, software %% distributed under the License is distributed on an "AS IS" BASIS, %% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. %% See the License for the specific language governing permissions and %% limitations under the License. %% %% %CopyrightEnd% %% %%%------------------------------------------------------------------- %%% File: ct_release_test_SUITE %%% %%% Description: %%% Test ct_release_test module %%% %%%------------------------------------------------------------------- -module(ct_release_test_SUITE). -compile(export_all). -include_lib("common_test/include/ct.hrl"). -include_lib("common_test/include/ct_event.hrl"). -define(eh, ct_test_support_eh). -define(suite, release_test_SUITE). %%-------------------------------------------------------------------- %% TEST SERVER CALLBACK FUNCTIONS %%-------------------------------------------------------------------- %%-------------------------------------------------------------------- %% Description: Since Common Test starts another Test Server %% instance, the tests need to be performed on a separate node (or %% there will be clashes with logging processes etc). %%-------------------------------------------------------------------- init_per_suite(Config) -> case os:type() of {win32,_} -> {skipped, "Upgrade tests do currently not work on windows"}; _ -> ct_test_support:init_per_suite(Config) end. end_per_suite(Config) -> ct_test_support:end_per_suite(Config). init_per_testcase(TestCase, Config) -> ct_test_support:init_per_testcase(TestCase, Config). end_per_testcase(TestCase, Config) -> ct_test_support:end_per_testcase(TestCase, Config). suite() -> [{ct_hooks,[ts_install_cth]}]. all() -> [ minor, major, major_fail_init, major_fail_upgraded, major_fail_downgraded, major_fail_no_init ]. %%-------------------------------------------------------------------- %% TEST CASES %%-------------------------------------------------------------------- %%%----------------------------------------------------------------- %%% minor(Config) when is_list(Config) -> {Suite,Cfg} = setup1(Config), {Opts,ERPid} = setup([{suite,Suite}, {testcase,minor}, {label,minor}|Cfg], Config), execute(minor, Opts, ERPid, Config). major(Config) when is_list(Config) -> {Suite,Cfg} = setup1(Config), {Opts,ERPid} = setup([{suite,Suite}, {testcase,major}, {label,major}|Cfg], Config), execute(major, Opts, ERPid, Config). major_fail_init(Config) when is_list(Config) -> {Suite,Cfg} = setup1(Config), {Opts,ERPid} = setup([{suite,Suite}, {testcase,major_fail_init}, {label,major_fail_init}|Cfg], Config), execute(major_fail_init, Opts, ERPid, Config). major_fail_upgraded(Config) when is_list(Config) -> {Suite,Cfg} = setup1(Config), {Opts,ERPid} = setup([{suite,Suite}, {testcase,major_fail_upgraded}, {label,major_fail_upgraded}|Cfg], Config), execute(major_fail_upgraded, Opts, ERPid, Config). major_fail_downgraded(Config) when is_list(Config) -> {Suite,Cfg} = setup1(Config), {Opts,ERPid} = setup([{suite,Suite}, {testcase,major_fail_downgraded}, {label,major_fail_downgraded}|Cfg], Config), execute(major_fail_downgraded, Opts, ERPid, Config). major_fail_no_init(Config) when is_list(Config) -> {Suite,Cfg} = setup1(Config), {Opts,ERPid} = setup([{suite,Suite}, {testcase,major_fail_no_init}, {label,major_fail_no_init}|Cfg], Config), execute(major_fail_no_init, Opts, ERPid, Config). %%%----------------------------------------------------------------- %%% HELP FUNCTIONS %%%----------------------------------------------------------------- setup1(Config) -> DataDir = ?config(data_dir, Config), Suite = filename:join(DataDir, atom_to_list(?suite)), Cfg = case ct:get_config(otp_releases) of undefined -> []; Rels -> CfgFile = filename:join(DataDir, "release_test.cfg"), file:write_file(CfgFile, io_lib:format("{otp_releases,~p}.",[Rels])), [{config,CfgFile}] end, {Suite,Cfg}. setup(Test, Config) -> Opts0 = ct_test_support:get_opts(Config), Level = ?config(trace_level, Config), EvHArgs = [{cbm,ct_test_support},{trace_level,Level}], Opts = Opts0 ++ [{event_handler,{?eh,EvHArgs}}|Test], ERPid = ct_test_support:start_event_receiver(Config), {Opts,ERPid}. execute(Name, Opts, ERPid, Config) -> ok = ct_test_support:run(Opts, Config), Events = ct_test_support:get_events(ERPid, Config), ct_test_support:log_events(Name, reformat(Events, ?eh), ?config(priv_dir, Config), Opts), verify_events(Name,Events,Config). reformat(Events, EH) -> ct_test_support:reformat(Events, EH). %%%----------------------------------------------------------------- %%% TEST EVENTS %%%----------------------------------------------------------------- verify_events(TC,Events,Config) -> Ok = expected_events(TC,ok), case ct_test_support:verify_events(Ok, Events, Config) of ok -> ok; {event_not_found,{?eh,tc_done,{_Suite,TC,ok}}}=R1 -> ct:log("Did not find 'ok', checking if skipped...",[]), Skipped = expected_events(TC,{skipped,"Old release not available"}), case ct_test_support:verify_events(Skipped, Events, Config) of ok -> {skipped,"Old release not available"}; R2 -> ct:log("Did not find skipped case either: ~n~p",[R2]), exit(R1) end end. expected_events(TC,Result) -> OneTest = [{?eh,start_logging,{'DEF','RUNDIR'}}, {?eh,tc_done,{?suite,TC,Result}}, {?eh,stop_logging,[]}], %% 2 tests (ct:run_test + script_start) is default OneTest ++ OneTest.