Signed-off-by: Max Carrara <m.carr...@proxmox.com>
---
Changes v3 --> v4:
  * Adapt test cases for changes to patch 01 where applicable

Changes v2 --> v3:
  * None

Changes v1 --> v2:
  * NEW: Split from patch 02

 test/Path/Makefile           |   1 +
 test/Path/path_push_tests.pl | 159 +++++++++++++++++++++++++++++++++++
 2 files changed, 160 insertions(+)
 create mode 100755 test/Path/path_push_tests.pl

diff --git a/test/Path/Makefile b/test/Path/Makefile
index 08d34ac..9dd95f1 100644
--- a/test/Path/Makefile
+++ b/test/Path/Makefile
@@ -2,6 +2,7 @@ TESTS = \
        path_components_tests.pl                                \
        path_is_absolute_relative_tests.pl                      \
        path_join_tests.pl                                      \
+       path_push_tests.pl                                      \
 
 
 TEST_TARGETS = $(addsuffix .t,$(basename ${TESTS}))
diff --git a/test/Path/path_push_tests.pl b/test/Path/path_push_tests.pl
new file mode 100755
index 0000000..4d9d779
--- /dev/null
+++ b/test/Path/path_push_tests.pl
@@ -0,0 +1,159 @@
+#!/usr/bin/env perl
+
+use lib '../../src';
+
+use strict;
+use warnings;
+
+use Test::More;
+
+use PVE::Path;
+
+my $cases = [
+    {
+       name => "push empty onto empty path",
+       path => "",
+       to_push => "",
+       pushed => "",
+    },
+    {
+       name => "push empty onto root",
+       path => "/",
+       to_push => "",
+       pushed => "/",
+    },
+    {
+       name => "push single component onto empty path",
+       path => "",
+       to_push => "foo",
+       pushed => "foo",
+    },
+    {
+       name => "push single component onto root",
+       path => "/",
+       to_push => "foo",
+       pushed => "/foo",
+    },
+    {
+       name => "push single component onto single component",
+       path => "foo",
+       to_push => "bar",
+       pushed => "foo/bar",
+    },
+    {
+       name => "push single component onto single component with trailing 
slash",
+       path => "foo/",
+       to_push => "bar",
+       pushed => "foo/bar",
+    },
+    {
+       name => "push single component with trailing slath onto single 
component",
+       path => "foo",
+       to_push => "bar/",
+       pushed => "foo/bar/",
+    },
+    {
+       name => "push single component with trailing slash"
+           . " onto single component with trailing slash",
+       path => "foo/",
+       to_push => "bar/",
+       pushed => "foo/bar/",
+    },
+    {
+       name => "push relative path onto relative path",
+       path => "foo/bar",
+       to_push => "baz/quo",
+       pushed => "foo/bar/baz/quo",
+    },
+    {
+       name => "push relative path onto relative path with trailing slash",
+       path => "foo/bar/",
+       to_push => "baz/quo",
+       pushed => "foo/bar/baz/quo",
+    },
+    {
+       name => "push relative path with trailing slash onto relative path",
+       path => "foo/bar",
+       to_push => "baz/quo/",
+       pushed => "foo/bar/baz/quo/",
+    },
+    {
+       name => "push relative path with trailing slash onto relative path with 
trailing slash",
+       path => "foo/bar/",
+       to_push => "baz/quo/",
+       pushed => "foo/bar/baz/quo/",
+    },
+    {
+       name => "push root onto relative path",
+       path => "foo/bar",
+       to_push => "/",
+       pushed => "/",
+    },
+    {
+       name => "push root onto absolute path",
+       path => "/foo/bar",
+       to_push => "/",
+       pushed => "/",
+    },
+    {
+       name => "push absolute path onto relative path",
+       path => "foo/bar",
+       to_push => "/baz/quo",
+       pushed => "/baz/quo",
+    },
+    {
+       name => "push absolute path onto absolute path",
+       path => "/foo/bar",
+       to_push => "/baz/quo",
+       pushed => "/baz/quo",
+    },
+];
+
+sub test_path_push : prototype($) {
+    my ($case) = @_;
+
+    my $name = "path_push: " . $case->{name};
+
+    my $pushed = eval { PVE::Path::path_push($case->{path}, $case->{to_push}); 
};
+
+    if ($@) {
+       fail($name);
+       diag("Failed to push onto path:\n$@");
+       return;
+    }
+
+    if (!is($pushed, $case->{pushed}, $name)) {
+       diag("=== Expected ===");
+       diag(explain($case->{pushed}));
+       diag("=== Got ===");
+       diag(explain($pushed));
+    }
+
+    return;
+}
+
+
+sub main : prototype() {
+    my $test_subs = [
+       \&test_path_push,
+    ];
+
+    plan(tests => scalar($cases->@*) * scalar($test_subs->@*));
+
+    for my $case ($cases->@*) {
+       for my $test_sub ($test_subs->@*) {
+           eval {
+               # suppress warnings here to make output less noisy for certain 
tests
+               local $SIG{__WARN__} = sub {};
+               $test_sub->($case);
+           };
+           warn "$@\n" if $@;
+       }
+    }
+
+    done_testing();
+
+    return;
+}
+
+main();
-- 
2.39.5



_______________________________________________
pve-devel mailing list
pve-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel

Reply via email to