aboutsummaryrefslogtreecommitdiff
path: root/t/14-jobs.t
diff options
context:
space:
mode:
Diffstat (limited to 't/14-jobs.t')
-rwxr-xr-xt/14-jobs.t97
1 files changed, 97 insertions, 0 deletions
diff --git a/t/14-jobs.t b/t/14-jobs.t
new file mode 100755
index 0000000..082a419
--- /dev/null
+++ b/t/14-jobs.t
@@ -0,0 +1,97 @@
+#!/usr/bin/env perl
+
+use 5.16.0;
+use strict;
+use warnings FATAL => 'all';
+use Test::More;
+use Capture::Tiny qw/ capture_merged /;
+use FindBin '$RealBin';
+use lib $RealBin;
+use lib "$RealBin/../SBO-Lib/lib";
+use Test::Execute;
+
+if ($ENV{TEST_INSTALL}) {
+ plan tests => 4;
+} else {
+ plan skip_all => "Only run these tests if TEST_INSTALL=1";
+}
+
+$path = "$RealBin/../";
+
+sub cleanup {
+ capture_merged {
+ system(qw!/sbin/removepkg nonexistentslackbuild!);
+ unlink "$RealBin/LO-jobs/nonexistentslackbuild/perf.dummy";
+ system(qw!rm -rf /tmp/SBo/nonexistentslackbuild-1.0!);
+ system(qw!rm -rf /tmp/package-nonexistentslackbuild!);
+ };
+}
+
+sub set_lo {
+ state $set = 0;
+ state $lo;
+ if ($_[0]) {
+ if ($set) { script (qw/ sboconfig -o /, $lo, { test => 0 }); }
+ } else {
+ ($lo) = script (qw/ sboconfig -l /, { expected => qr/LOCAL_OVERRIDES=(.*)/, test => 0 });
+ $lo //= 'FALSE';
+ note "Saving original value of LOCAL_OVERRIDES: $lo";
+ $set = 1;
+ script (qw/ sboconfig -o /, "$RealBin/LO-jobs", { test => 0 });
+ }
+}
+
+sub set_jobs {
+ state $set = 0;
+ state $jobs;
+ if ($_[0]) {
+ if ($set) { script (qw/ sboconfig -j /, $jobs, { test => 0 }); }
+ } else {
+ ($jobs) = script (qw/ sboconfig -l /, { expected => qr/JOBS=(.*)/, test => 0 });
+ $jobs //= 'FALSE';
+ note "Saving original value of JOBS: $jobs";
+ $set = 1;
+ script (qw/ sboconfig -j FALSE /, { test => 0 });
+ }
+}
+
+cleanup();
+set_lo();
+set_jobs();
+
+# 1: sboinstall with jobs set to FALSE
+{
+ my ($time) = script (qw/ sboinstall -r nonexistentslackbuild /, { expected => qr/\nreal\s+\d+m([0-9.]+)s\n/, test => 0, });
+ ok ($time > 5, "jobs set to FALSE took the expected amount of time");
+}
+script (qw/ sboremove nonexistentslackbuild /, { input => "y\ny", test => 0 });
+
+# 2: sboinstall with jobs set to 2
+script (qw/ sboconfig -j 2 /, { test => 0 });
+{
+ my ($time) = script (qw/ sboinstall -r nonexistentslackbuild /, { expected => qr/^real\s+\d+m([\d.]+)s$/m, test => 0 });
+ ok ($time < 5, "jobs set to 2 took less time than otherwise");
+}
+script (qw/ sboremove nonexistentslackbuild /, { input => "y\ny", test => 0 });
+
+# 3: sboinstall -j FALSE with jobs set to 2
+{
+ my ($time) = script (qw/ sboinstall -j FALSE -r nonexistentslackbuild /, { expected => qr/^real\s+\d+m([\d.]+)s$/m, test => 0 });
+ ok ($time > 5, "-j FALSE took the expected amount of time");
+}
+script (qw/ sboremove nonexistentslackbuild /, { input => "y\ny", test => 0 });
+
+# 4: sboinstall -j 2 with jobs set to FALSE
+script (qw/ sboconfig -j FALSE /, { test => 0 });
+{
+ my ($time) = script (qw/ sboinstall -j 2 -r nonexistentslackbuild /, { expected => qr/^real\s+\d+m([\d.]+)s$/m, test => 0 });
+ ok ($time < 5, "-j 2 took less time than otherwise");
+}
+script (qw/ sboremove nonexistentslackbuild /, { input => "y\ny", test => 0 });
+
+# Cleanup
+END {
+ set_jobs('delete');
+ set_lo('delete');
+ cleanup();
+}