summaryrefslogtreecommitdiff
path: root/inttest
diff options
context:
space:
mode:
authorFred Hebert <mononcqc@ferd.ca>2015-02-05 08:12:43 -0500
committerFred Hebert <mononcqc@ferd.ca>2015-02-05 08:12:43 -0500
commit7f73b8d3650b41ffd53a199f3eda20985eda84e3 (patch)
tree8409edbb706c202f2edaa07eca05f33cc44b3130 /inttest
parent0eecd4d050a9681622c38df8c31f27e63fac0170 (diff)
parent53fbb7cf8e99b0a93108b7889ab22a3ad2e05b41 (diff)
downloadrebar-7f73b8d3650b41ffd53a199f3eda20985eda84e3.tar.gz
Merge pull request #449 from lrascao/feature/support_appup_src_files
Support .appup.src files
Diffstat (limited to 'inttest')
-rw-r--r--inttest/appup_src/appup_src_rt.erl67
-rw-r--r--inttest/appup_src/src/app.app.src5
-rw-r--r--inttest/appup_src/src/app.appup.src6
-rw-r--r--inttest/appup_src/src/appup_src.erl6
-rw-r--r--inttest/appup_src_script/appup_src_script_rt.erl67
-rw-r--r--inttest/appup_src_script/src/app.app.src5
-rw-r--r--inttest/appup_src_script/src/app.appup.src6
-rw-r--r--inttest/appup_src_script/src/app.appup.src.script9
-rw-r--r--inttest/appup_src_script/src/appup_src.erl6
9 files changed, 177 insertions, 0 deletions
diff --git a/inttest/appup_src/appup_src_rt.erl b/inttest/appup_src/appup_src_rt.erl
new file mode 100644
index 0000000..43d3c5d
--- /dev/null
+++ b/inttest/appup_src/appup_src_rt.erl
@@ -0,0 +1,67 @@
+%% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*-
+%% ex: ts=4 sw=4 et
+%% -------------------------------------------------------------------
+%%
+%% rebar: Erlang Build Tools
+%%
+%% Copyright (c) 2015 Luis Rascao (luis.rascao@gmail.com)
+%%
+%% Permission is hereby granted, free of charge, to any person obtaining a copy
+%% of this software and associated documentation files (the "Software"), to deal
+%% in the Software without restriction, including without limitation the rights
+%% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+%% copies of the Software, and to permit persons to whom the Software is
+%% furnished to do so, subject to the following conditions:
+%%
+%% The above copyright notice and this permission notice shall be included in
+%% all copies or substantial portions of the Software.
+%%
+%% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+%% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+%% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+%% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+%% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+%% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+%% THE SOFTWARE.
+%% -------------------------------------------------------------------
+-module(appup_src_rt).
+
+-compile(export_all).
+
+-include_lib("eunit/include/eunit.hrl").
+
+files() ->
+ [{copy, "../../rebar", "rebar"},
+ {copy, "src", "src"}].
+
+run(Dir) ->
+ retest_log:log(debug, "Running in Dir: ~s~n", [Dir]),
+ {ok, [_Pid|Output]} = retest:sh("./rebar compile -vv",
+ [{async, false}]),
+
+ LineRegexp = "Compiled src/app\.appup\.src",
+ ?assertEqual(true, has_line(Output, LineRegexp)),
+
+ %% check that ebin/app.appup exists
+ ?assertMatch(true, filelib:is_regular("ebin/app.appup")),
+ retest_log:log(debug, "Generated ebin/app.appup~n", []),
+
+ %% check that ebin/app.appup has expected version
+ {ok, [{AppVersion, [{UpgradeFrom, _}], [{DowngradeTo, _}]}]} =
+ file:consult("ebin/app.appup"),
+ ?assertEqual(AppVersion, "1.2.2"),
+ ?assertEqual(UpgradeFrom, "1.2.1"),
+ ?assertEqual(DowngradeTo, "1.2.1"),
+ ok.
+
+has_line([], _RE) ->
+ false;
+has_line([L|T], RE) ->
+ case re:run(L, RE, []) of
+ {match, _Captured} ->
+ true;
+ match ->
+ true;
+ nomatch ->
+ has_line(T, RE)
+ end.
diff --git a/inttest/appup_src/src/app.app.src b/inttest/appup_src/src/app.app.src
new file mode 100644
index 0000000..9a63bb3
--- /dev/null
+++ b/inttest/appup_src/src/app.app.src
@@ -0,0 +1,5 @@
+{application, app,
+ [{vsn, "1"},
+ {modules, []},
+ {registered, []},
+ {applications, [kernel, stdlib]}]}.
diff --git a/inttest/appup_src/src/app.appup.src b/inttest/appup_src/src/app.appup.src
new file mode 100644
index 0000000..1ca946a
--- /dev/null
+++ b/inttest/appup_src/src/app.appup.src
@@ -0,0 +1,6 @@
+{"1.2.2",
+ [{"1.2.1",
+ [{update,proc1,{advanced,[]},[]},
+ {update,proc2,{advanced,[]},[]}]
+ }],
+ [{"1.2.1", []}]}.
diff --git a/inttest/appup_src/src/appup_src.erl b/inttest/appup_src/src/appup_src.erl
new file mode 100644
index 0000000..6f4d0d7
--- /dev/null
+++ b/inttest/appup_src/src/appup_src.erl
@@ -0,0 +1,6 @@
+-module(appup_src).
+
+-compile(export_all).
+
+test() ->
+ ok.
diff --git a/inttest/appup_src_script/appup_src_script_rt.erl b/inttest/appup_src_script/appup_src_script_rt.erl
new file mode 100644
index 0000000..c98e54e
--- /dev/null
+++ b/inttest/appup_src_script/appup_src_script_rt.erl
@@ -0,0 +1,67 @@
+%% -*- erlang-indent-level: 4;indent-tabs-mode: nil -*-
+%% ex: ts=4 sw=4 et
+%% -------------------------------------------------------------------
+%%
+%% rebar: Erlang Build Tools
+%%
+%% Copyright (c) 2015 Luis Rascao (luis.rascao@gmail.com)
+%%
+%% Permission is hereby granted, free of charge, to any person obtaining a copy
+%% of this software and associated documentation files (the "Software"), to deal
+%% in the Software without restriction, including without limitation the rights
+%% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+%% copies of the Software, and to permit persons to whom the Software is
+%% furnished to do so, subject to the following conditions:
+%%
+%% The above copyright notice and this permission notice shall be included in
+%% all copies or substantial portions of the Software.
+%%
+%% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+%% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+%% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+%% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+%% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+%% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+%% THE SOFTWARE.
+%% -------------------------------------------------------------------
+-module(appup_src_script_rt).
+
+-compile(export_all).
+
+-include_lib("eunit/include/eunit.hrl").
+
+files() ->
+ [{copy, "../../rebar", "rebar"},
+ {copy, "src", "src"}].
+
+run(Dir) ->
+ retest_log:log(debug, "Running in Dir: ~s~n", [Dir]),
+ {ok, [_Pid|Output]} = retest:sh("./rebar compile -vv",
+ [{async, false}]),
+
+ LineRegexp = "Compiled src/app\.appup\.src",
+ ?assertEqual(true, has_line(Output, LineRegexp)),
+
+ %% check that ebin/app.appup exists
+ ?assertMatch(true, filelib:is_regular("ebin/app.appup")),
+ retest_log:log(debug, "Generated ebin/app.appup~n", []),
+
+ %% check that ebin/app.appup has expected version
+ {ok, [{AppVersion, [{UpgradeFrom, _}], [{DowngradeTo, _}]}]} =
+ file:consult("ebin/app.appup"),
+ ?assertEqual(AppVersion, "2.1.2"),
+ ?assertEqual(UpgradeFrom, "2.1.1"),
+ ?assertEqual(DowngradeTo, "2.1.1"),
+ ok.
+
+has_line([], _RE) ->
+ false;
+has_line([L|T], RE) ->
+ case re:run(L, RE, []) of
+ {match, _Captured} ->
+ true;
+ match ->
+ true;
+ nomatch ->
+ has_line(T, RE)
+ end.
diff --git a/inttest/appup_src_script/src/app.app.src b/inttest/appup_src_script/src/app.app.src
new file mode 100644
index 0000000..9a63bb3
--- /dev/null
+++ b/inttest/appup_src_script/src/app.app.src
@@ -0,0 +1,5 @@
+{application, app,
+ [{vsn, "1"},
+ {modules, []},
+ {registered, []},
+ {applications, [kernel, stdlib]}]}.
diff --git a/inttest/appup_src_script/src/app.appup.src b/inttest/appup_src_script/src/app.appup.src
new file mode 100644
index 0000000..1ca946a
--- /dev/null
+++ b/inttest/appup_src_script/src/app.appup.src
@@ -0,0 +1,6 @@
+{"1.2.2",
+ [{"1.2.1",
+ [{update,proc1,{advanced,[]},[]},
+ {update,proc2,{advanced,[]},[]}]
+ }],
+ [{"1.2.1", []}]}.
diff --git a/inttest/appup_src_script/src/app.appup.src.script b/inttest/appup_src_script/src/app.appup.src.script
new file mode 100644
index 0000000..8dc3f98
--- /dev/null
+++ b/inttest/appup_src_script/src/app.appup.src.script
@@ -0,0 +1,9 @@
+%% decompose the appup
+[{AppVersion,
+ [{UpgradeFrom, UpgradeInstructions}],
+ [{DowngradeTo, DowngradeInstructions}]}] = CONFIG,
+
+%% and replace the version strings
+[{"2.1.2",
+ [{"2.1.1", UpgradeInstructions}],
+ [{"2.1.1", DowngradeInstructions}]}].
diff --git a/inttest/appup_src_script/src/appup_src.erl b/inttest/appup_src_script/src/appup_src.erl
new file mode 100644
index 0000000..6f4d0d7
--- /dev/null
+++ b/inttest/appup_src_script/src/appup_src.erl
@@ -0,0 +1,6 @@
+-module(appup_src).
+
+-compile(export_all).
+
+test() ->
+ ok.