| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- use strict;
- use warnings;
- use FindBin;
- use lib $FindBin::Bin.'/../bin';
- require 'testrail-report';
- use Test::More 'tests' => 16;
- use IO::CaptureOutput qw{capture};
- my @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project}, "CRUSH ALL HUMANS", '--run', "SEND T-1000 INFILTRATION UNITS BACK IN TIME", qw{--mock t/test_multiple_files.tap});
- my $out;
- my (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK reported with multiple files");
- my $matches = () = $out =~ m/Reporting result of case/ig;
- is($matches,2,"Attempts to upload multiple times");
- @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project}, "CRUSH ALL HUMANS", '--run', "SEND T-1000 INFILTRATION UNITS BACK IN TIME", qw{--case-ok --mock t/test_multiple_files.tap});
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK reported with multiple files (case-ok mode)");
- $matches = () = $out =~ m/Reporting result of case/ig;
- is($matches,4,"Attempts to upload multiple times (case-ok mode)");
- #Test version, case-ok
- @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project TestProject --run TestingSuite --case-ok --version 1.0.14 --mock t/test_subtest.tap});
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK reported with subtests (case-ok mode)");
- $matches = () = $out =~ m/Reporting result of case/ig;
- is($matches,2,"Attempts to upload do not do subtests (case-ok mode)");
- #Test plans/configs
- @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project TestProject --run}, "Executing the great plan", qw{--plan GosPlan --config testConfig --case-ok --mock t/test_subtest.tap});
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK reported with plans");
- $matches = () = $out =~ m/Reporting result of case.*OK/ig;
- is($matches,2,"Attempts to to plans work");
- #Test that spawn works
- @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project TestProject --run TestingSuite2 --testsuite_id 9 --case-ok --mock t/test_subtest.tap});
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK reported with spawn");
- $matches = () = $out =~ m/Reporting result of case.*OK/ig;
- is($matches,2,"Attempts to spawn work: testsuite_id");
- #Test that spawn works w/sections
- @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project TestProject --run TestingSuite2 --testsuite}, "HAMBURGER-IZE HUMANITY", qw{--case-ok --section}, "CARBON LIQUEFACTION", qw{--mock t/test_subtest.tap});
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK reported with spawn");
- $matches = () = $out =~ m/with specified sections/ig;
- is($matches,1,"Attempts to spawn work: testsuite name");
- #Test that the autoclose option works
- @args = (qw{--apiurl http://testrail.local --user test@fake.fake --password fake --project TestProject --run FinalRun --plan FinalPlan --config testConfig --case-ok --autoclose --mock t/fake.tap});
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK when doing autoclose");
- like($out,qr/closing plan/i,"Run closure reported to user");
- #Test that help works
- @args = qw{--help};
- $0 = $FindBin::Bin.'/../bin/testrail-report';
- (undef,$code) = capture {TestRail::Bin::Report::run(@args)} \$out, \$out;
- is($code, 0, "Exit code OK asking for help");
- like($out,qr/encoding of arguments/i,"Help output OK");
|