blob: bce569f8876a568b3936c94ee7734dfa72cc2d84 [file] [log] [blame]
// Copyright 2014 The Bazel Authors. 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.
package com.google.devtools.build.lib.vfs;
import static com.google.common.truth.Truth.assertThat;
import static org.junit.Assert.fail;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Lists;
import com.google.common.testing.EqualsTester;
import com.google.devtools.build.lib.testutil.TestUtils;
import com.google.devtools.build.lib.vfs.inmemoryfs.InMemoryFileSystem;
import java.io.File;
import java.util.Collections;
import java.util.List;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
/**
* This class tests the functionality of the PathFragment.
*/
@RunWith(JUnit4.class)
public class PathFragmentTest {
@Test
public void testMergeFourPathsWithAbsolute() {
assertThat(
PathFragment.create(
PathFragment.create("x/y"),
PathFragment.create("z/a"),
PathFragment.create("/b/c"),
PathFragment.create("d/e")))
.isEqualTo(PathFragment.create("x/y/z/a/b/c/d/e"));
}
@Test
public void testCreateInternsPathFragments() {
String[] firstSegments = new String[] {"hello", "world"};
PathFragment first = PathFragment.create(
/*driveLetter=*/ '\0', /*isAbsolute=*/ false, firstSegments);
String[] secondSegments = new String[] {new String("hello"), new String("world")};
PathFragment second = PathFragment.create(
/*driveLetter=*/ '\0', /*isAbsolute=*/ false, secondSegments);
assertThat(first.segmentCount()).isEqualTo(second.segmentCount());
for (int i = 0; i < first.segmentCount(); i++) {
assertThat(first.getSegment(i)).isSameAs(second.getSegment(i));
}
}
@Test
public void testEqualsAndHashCode() {
InMemoryFileSystem filesystem = new InMemoryFileSystem();
new EqualsTester()
.addEqualityGroup(
PathFragment.create("../relative/path"),
PathFragment.create("..").getRelative("relative").getRelative("path"),
PathFragment.createAlreadyInterned(
'\0', false, new String[] {"..", "relative", "path"}),
PathFragment.create(new File("../relative/path")))
.addEqualityGroup(PathFragment.create("something/else"))
.addEqualityGroup(PathFragment.create("/something/else"))
.addEqualityGroup(PathFragment.create("/"), PathFragment.create("//////"))
.addEqualityGroup(PathFragment.create(""), PathFragment.EMPTY_FRAGMENT)
.addEqualityGroup(filesystem.getRootDirectory()) // A Path object.
.testEquals();
}
@Test
public void testHashCodeCache() {
PathFragment relativePath = PathFragment.create("../relative/path");
PathFragment rootPath = PathFragment.create("/");
int oldResult = relativePath.hashCode();
int rootResult = rootPath.hashCode();
assertThat(relativePath.hashCode()).isEqualTo(oldResult);
assertThat(rootPath.hashCode()).isEqualTo(rootResult);
}
private void checkRelativeTo(String path, String base) {
PathFragment relative = PathFragment.create(path).relativeTo(base);
assertThat(PathFragment.create(base).getRelative(relative).normalize())
.isEqualTo(PathFragment.create(path));
}
@Test
public void testRelativeTo() {
assertPath("bar/baz", PathFragment.create("foo/bar/baz").relativeTo("foo"));
assertPath("bar/baz", PathFragment.create("/foo/bar/baz").relativeTo("/foo"));
assertPath("baz", PathFragment.create("foo/bar/baz").relativeTo("foo/bar"));
assertPath("baz", PathFragment.create("/foo/bar/baz").relativeTo("/foo/bar"));
assertPath("foo", PathFragment.create("/foo").relativeTo("/"));
assertPath("foo", PathFragment.create("foo").relativeTo(""));
assertPath("foo/bar", PathFragment.create("foo/bar").relativeTo(""));
checkRelativeTo("foo/bar/baz", "foo");
checkRelativeTo("/foo/bar/baz", "/foo");
checkRelativeTo("foo/bar/baz", "foo/bar");
checkRelativeTo("/foo/bar/baz", "/foo/bar");
checkRelativeTo("/foo", "/");
checkRelativeTo("foo", "");
checkRelativeTo("foo/bar", "");
}
@Test
public void testIsAbsolute() {
assertThat(PathFragment.create("/absolute/test").isAbsolute()).isTrue();
assertThat(PathFragment.create("relative/test").isAbsolute()).isFalse();
assertThat(PathFragment.create(new File("/absolute/test")).isAbsolute()).isTrue();
assertThat(PathFragment.create(new File("relative/test")).isAbsolute()).isFalse();
}
@Test
public void testIsNormalized() {
assertThat(PathFragment.create("/absolute/path").isNormalized()).isTrue();
assertThat(PathFragment.create("some//path").isNormalized()).isTrue();
assertThat(PathFragment.create("some/./path").isNormalized()).isFalse();
assertThat(PathFragment.create("../some/path").isNormalized()).isFalse();
assertThat(PathFragment.create("some/other/../path").isNormalized()).isFalse();
assertThat(PathFragment.create("some/other//tricky..path..").isNormalized()).isTrue();
assertThat(PathFragment.create("/some/other//tricky..path..").isNormalized()).isTrue();
}
@Test
public void testRootNodeReturnsRootString() {
PathFragment rootFragment = PathFragment.create("/");
assertThat(rootFragment.getPathString()).isEqualTo("/");
}
@Test
public void testGetPathFragmentDoesNotNormalize() {
String nonCanonicalPath = "/a/weird/noncanonical/../path/.";
assertThat(PathFragment.create(nonCanonicalPath).getPathString()).isEqualTo(nonCanonicalPath);
}
@Test
public void testGetRelative() {
assertThat(PathFragment.create("a").getRelative("b").getPathString()).isEqualTo("a/b");
assertThat(PathFragment.create("a/b").getRelative("c/d").getPathString()).isEqualTo("a/b/c/d");
assertThat(PathFragment.create("c/d").getRelative("/a/b").getPathString()).isEqualTo("/a/b");
assertThat(PathFragment.create("a").getRelative("").getPathString()).isEqualTo("a");
assertThat(PathFragment.create("/").getRelative("").getPathString()).isEqualTo("/");
}
@Test
public void testGetChildWorks() {
PathFragment pf = PathFragment.create("../some/path");
assertThat(pf.getChild("hi")).isEqualTo(PathFragment.create("../some/path/hi"));
}
@Test
public void testGetChildRejectsInvalidBaseNames() {
PathFragment pf = PathFragment.create("../some/path");
assertGetChildFails(pf, ".");
assertGetChildFails(pf, "..");
assertGetChildFails(pf, "x/y");
assertGetChildFails(pf, "/y");
assertGetChildFails(pf, "y/");
assertGetChildFails(pf, "");
}
private void assertGetChildFails(PathFragment pf, String baseName) {
try {
pf.getChild(baseName);
fail();
} catch (Exception e) { /* Expected. */ }
}
// Tests after here test the canonicalization
private void assertRegular(String expected, String actual) {
// compare string forms
assertThat(PathFragment.create(actual).getPathString()).isEqualTo(expected);
// compare fragment forms
assertThat(PathFragment.create(actual)).isEqualTo(PathFragment.create(expected));
}
@Test
public void testEmptyPathToEmptyPath() {
assertRegular("/", "/");
assertRegular("", "");
}
@Test
public void testRedundantSlashes() {
assertRegular("/", "///");
assertRegular("/foo/bar", "/foo///bar");
assertRegular("/foo/bar", "////foo//bar");
}
@Test
public void testSimpleNameToSimpleName() {
assertRegular("/foo", "/foo");
assertRegular("foo", "foo");
}
@Test
public void testSimplePathToSimplePath() {
assertRegular("/foo/bar", "/foo/bar");
assertRegular("foo/bar", "foo/bar");
}
@Test
public void testStripsTrailingSlash() {
assertRegular("/foo/bar", "/foo/bar/");
}
@Test
public void testGetParentDirectory() {
PathFragment fooBarWiz = PathFragment.create("foo/bar/wiz");
PathFragment fooBar = PathFragment.create("foo/bar");
PathFragment foo = PathFragment.create("foo");
PathFragment empty = PathFragment.create("");
assertThat(fooBarWiz.getParentDirectory()).isEqualTo(fooBar);
assertThat(fooBar.getParentDirectory()).isEqualTo(foo);
assertThat(foo.getParentDirectory()).isEqualTo(empty);
assertThat(empty.getParentDirectory()).isNull();
PathFragment fooBarWizAbs = PathFragment.create("/foo/bar/wiz");
PathFragment fooBarAbs = PathFragment.create("/foo/bar");
PathFragment fooAbs = PathFragment.create("/foo");
PathFragment rootAbs = PathFragment.create("/");
assertThat(fooBarWizAbs.getParentDirectory()).isEqualTo(fooBarAbs);
assertThat(fooBarAbs.getParentDirectory()).isEqualTo(fooAbs);
assertThat(fooAbs.getParentDirectory()).isEqualTo(rootAbs);
assertThat(rootAbs.getParentDirectory()).isNull();
// Note, this is surprising but correct behavior:
assertThat(PathFragment.create("/foo/bar/..").getParentDirectory()).isEqualTo(fooBarAbs);
}
@Test
public void testSegmentsCount() {
assertThat(PathFragment.create("foo/bar").segmentCount()).isEqualTo(2);
assertThat(PathFragment.create("/foo/bar").segmentCount()).isEqualTo(2);
assertThat(PathFragment.create("foo//bar").segmentCount()).isEqualTo(2);
assertThat(PathFragment.create("/foo//bar").segmentCount()).isEqualTo(2);
assertThat(PathFragment.create("foo/").segmentCount()).isEqualTo(1);
assertThat(PathFragment.create("/foo/").segmentCount()).isEqualTo(1);
assertThat(PathFragment.create("foo").segmentCount()).isEqualTo(1);
assertThat(PathFragment.create("/foo").segmentCount()).isEqualTo(1);
assertThat(PathFragment.create("/").segmentCount()).isEqualTo(0);
assertThat(PathFragment.create("").segmentCount()).isEqualTo(0);
}
@Test
public void testGetSegment() {
assertThat(PathFragment.create("foo/bar").getSegment(0)).isEqualTo("foo");
assertThat(PathFragment.create("foo/bar").getSegment(1)).isEqualTo("bar");
assertThat(PathFragment.create("/foo/bar").getSegment(0)).isEqualTo("foo");
assertThat(PathFragment.create("/foo/bar").getSegment(1)).isEqualTo("bar");
assertThat(PathFragment.create("foo/").getSegment(0)).isEqualTo("foo");
assertThat(PathFragment.create("/foo/").getSegment(0)).isEqualTo("foo");
assertThat(PathFragment.create("foo").getSegment(0)).isEqualTo("foo");
assertThat(PathFragment.create("/foo").getSegment(0)).isEqualTo("foo");
}
@Test
public void testBasename() throws Exception {
assertThat(PathFragment.create("foo/bar").getBaseName()).isEqualTo("bar");
assertThat(PathFragment.create("/foo/bar").getBaseName()).isEqualTo("bar");
assertThat(PathFragment.create("foo/").getBaseName()).isEqualTo("foo");
assertThat(PathFragment.create("/foo/").getBaseName()).isEqualTo("foo");
assertThat(PathFragment.create("foo").getBaseName()).isEqualTo("foo");
assertThat(PathFragment.create("/foo").getBaseName()).isEqualTo("foo");
assertThat(PathFragment.create("/").getBaseName()).isEmpty();
assertThat(PathFragment.create("").getBaseName()).isEmpty();
}
@Test
public void testFileExtension() throws Exception {
assertThat(PathFragment.create("foo.bar").getFileExtension()).isEqualTo("bar");
assertThat(PathFragment.create("foo.barr").getFileExtension()).isEqualTo("barr");
assertThat(PathFragment.create("foo.b").getFileExtension()).isEqualTo("b");
assertThat(PathFragment.create("foo.").getFileExtension()).isEmpty();
assertThat(PathFragment.create("foo").getFileExtension()).isEmpty();
assertThat(PathFragment.create(".").getFileExtension()).isEmpty();
assertThat(PathFragment.create("").getFileExtension()).isEmpty();
assertThat(PathFragment.create("foo/bar.baz").getFileExtension()).isEqualTo("baz");
assertThat(PathFragment.create("foo.bar.baz").getFileExtension()).isEqualTo("baz");
assertThat(PathFragment.create("foo.bar/baz").getFileExtension()).isEmpty();
}
private static void assertPath(String expected, PathFragment actual) {
assertThat(actual.getPathString()).isEqualTo(expected);
}
@Test
public void testReplaceName() throws Exception {
assertPath("foo/baz", PathFragment.create("foo/bar").replaceName("baz"));
assertPath("/foo/baz", PathFragment.create("/foo/bar").replaceName("baz"));
assertPath("foo", PathFragment.create("foo/bar").replaceName(""));
assertPath("baz", PathFragment.create("foo/").replaceName("baz"));
assertPath("/baz", PathFragment.create("/foo/").replaceName("baz"));
assertPath("baz", PathFragment.create("foo").replaceName("baz"));
assertPath("/baz", PathFragment.create("/foo").replaceName("baz"));
assertThat(PathFragment.create("/").replaceName("baz")).isNull();
assertThat(PathFragment.create("/").replaceName("")).isNull();
assertThat(PathFragment.create("").replaceName("baz")).isNull();
assertThat(PathFragment.create("").replaceName("")).isNull();
assertPath("foo/bar/baz", PathFragment.create("foo/bar").replaceName("bar/baz"));
assertPath("foo/bar/baz", PathFragment.create("foo/bar").replaceName("bar/baz/"));
// Absolute path arguments will clobber the original path.
assertPath("/absolute", PathFragment.create("foo/bar").replaceName("/absolute"));
assertPath("/", PathFragment.create("foo/bar").replaceName("/"));
}
@Test
public void testSubFragment() throws Exception {
assertPath("/foo/bar/baz",
PathFragment.create("/foo/bar/baz").subFragment(0, 3));
assertPath("foo/bar/baz",
PathFragment.create("foo/bar/baz").subFragment(0, 3));
assertPath("/foo/bar",
PathFragment.create("/foo/bar/baz").subFragment(0, 2));
assertPath("bar/baz",
PathFragment.create("/foo/bar/baz").subFragment(1, 3));
assertPath("/foo",
PathFragment.create("/foo/bar/baz").subFragment(0, 1));
assertPath("bar",
PathFragment.create("/foo/bar/baz").subFragment(1, 2));
assertPath("baz", PathFragment.create("/foo/bar/baz").subFragment(2, 3));
assertPath("/", PathFragment.create("/foo/bar/baz").subFragment(0, 0));
assertPath("", PathFragment.create("foo/bar/baz").subFragment(0, 0));
assertPath("", PathFragment.create("foo/bar/baz").subFragment(1, 1));
try {
fail("unexpectedly succeeded: " + PathFragment.create("foo/bar/baz").subFragment(3, 2));
} catch (IndexOutOfBoundsException e) { /* Expected. */ }
try {
fail("unexpectedly succeeded: " + PathFragment.create("foo/bar/baz").subFragment(4, 4));
} catch (IndexOutOfBoundsException e) { /* Expected. */ }
}
@Test
public void testStartsWith() {
PathFragment foobar = PathFragment.create("/foo/bar");
PathFragment foobarRelative = PathFragment.create("foo/bar");
// (path, prefix) => true
assertThat(foobar.startsWith(foobar)).isTrue();
assertThat(foobar.startsWith(PathFragment.create("/"))).isTrue();
assertThat(foobar.startsWith(PathFragment.create("/foo"))).isTrue();
assertThat(foobar.startsWith(PathFragment.create("/foo/"))).isTrue();
assertThat(foobar.startsWith(PathFragment.create("/foo/bar/")))
.isTrue(); // Includes trailing slash.
// (prefix, path) => false
assertThat(PathFragment.create("/foo").startsWith(foobar)).isFalse();
assertThat(PathFragment.create("/").startsWith(foobar)).isFalse();
// (absolute, relative) => false
assertThat(foobar.startsWith(foobarRelative)).isFalse();
assertThat(foobarRelative.startsWith(foobar)).isFalse();
// (relative path, relative prefix) => true
assertThat(foobarRelative.startsWith(foobarRelative)).isTrue();
assertThat(foobarRelative.startsWith(PathFragment.create("foo"))).isTrue();
assertThat(foobarRelative.startsWith(PathFragment.create(""))).isTrue();
// (path, sibling) => false
assertThat(PathFragment.create("/foo/wiz").startsWith(foobar)).isFalse();
assertThat(foobar.startsWith(PathFragment.create("/foo/wiz"))).isFalse();
// Does not normalize.
PathFragment foodotbar = PathFragment.create("foo/./bar");
assertThat(foodotbar.startsWith(foodotbar)).isTrue();
assertThat(foodotbar.startsWith(PathFragment.create("foo/."))).isTrue();
assertThat(foodotbar.startsWith(PathFragment.create("foo/./"))).isTrue();
assertThat(foodotbar.startsWith(PathFragment.create("foo/./bar"))).isTrue();
assertThat(foodotbar.startsWith(PathFragment.create("foo/bar"))).isFalse();
}
@Test
public void testFilterPathsStartingWith() {
// Retains everything:
ImmutableSet<PathFragment> allUnderA = toPathsSet("a/b", "a/c", "a/d");
assertThat(PathFragment.filterPathsStartingWith(allUnderA, PathFragment.create("a")))
.containsExactlyElementsIn(allUnderA);
// Retains some but not others:
ImmutableSet<PathFragment> mixed = toPathsSet("a/b", "a/c", "b/c");
assertThat(PathFragment.filterPathsStartingWith(mixed,
PathFragment.create("a"))).containsExactlyElementsIn(toPathsSet("a/b", "a/c"));
// Retains none:
assertThat(PathFragment.filterPathsStartingWith(allUnderA, PathFragment.create("b"))).isEmpty();
// Retains paths equal to the startingWithPath:
assertThat(PathFragment.filterPathsStartingWith(toPathsSet("a"),
PathFragment.create("a"))).containsExactlyElementsIn(toPathsSet("a"));
// Retains everything when startingWithPath is the empty fragment:
assertThat(PathFragment.filterPathsStartingWith(mixed, PathFragment.EMPTY_FRAGMENT))
.containsExactlyElementsIn(mixed);
// Supports multi-segment startingWithPaths:
assertThat(PathFragment.filterPathsStartingWith(toPathsSet("a/b/c", "a/b/d", "a/c/d"),
PathFragment.create("a/b"))).containsExactlyElementsIn(toPathsSet("a/b/c", "a/b/d"));
}
@Test
public void testCheckAllPathsStartWithButAreNotEqualTo() {
// Check passes:
PathFragment.checkAllPathsAreUnder(toPathsSet("a/b", "a/c"),
PathFragment.create("a"));
// Check trivially passes:
PathFragment.checkAllPathsAreUnder(ImmutableList.<PathFragment>of(),
PathFragment.create("a"));
// Check fails when some path does not start with startingWithPath:
try {
PathFragment.checkAllPathsAreUnder(toPathsSet("a/b", "b/c"),
PathFragment.create("a"));
fail();
} catch (IllegalArgumentException expected) {
}
// Check fails when some path is equal to startingWithPath:
try {
PathFragment.checkAllPathsAreUnder(toPathsSet("a/b", "a"),
PathFragment.create("a"));
fail();
} catch (IllegalArgumentException expected) {
}
}
@Test
public void testEndsWith() {
PathFragment foobar = PathFragment.create("/foo/bar");
PathFragment foobarRelative = PathFragment.create("foo/bar");
// (path, suffix) => true
assertThat(foobar.endsWith(foobar)).isTrue();
assertThat(foobar.endsWith(PathFragment.create("bar"))).isTrue();
assertThat(foobar.endsWith(PathFragment.create("foo/bar"))).isTrue();
assertThat(foobar.endsWith(PathFragment.create("/foo/bar"))).isTrue();
assertThat(foobar.endsWith(PathFragment.create("/bar"))).isFalse();
// (prefix, path) => false
assertThat(PathFragment.create("/foo").endsWith(foobar)).isFalse();
assertThat(PathFragment.create("/").endsWith(foobar)).isFalse();
// (suffix, path) => false
assertThat(PathFragment.create("/bar").endsWith(foobar)).isFalse();
assertThat(PathFragment.create("bar").endsWith(foobar)).isFalse();
assertThat(PathFragment.create("").endsWith(foobar)).isFalse();
// (absolute, relative) => true
assertThat(foobar.endsWith(foobarRelative)).isTrue();
// (relative, absolute) => false
assertThat(foobarRelative.endsWith(foobar)).isFalse();
// (relative path, relative prefix) => true
assertThat(foobarRelative.endsWith(foobarRelative)).isTrue();
assertThat(foobarRelative.endsWith(PathFragment.create("bar"))).isTrue();
assertThat(foobarRelative.endsWith(PathFragment.create(""))).isTrue();
// (path, sibling) => false
assertThat(PathFragment.create("/foo/wiz").endsWith(foobar)).isFalse();
assertThat(foobar.endsWith(PathFragment.create("/foo/wiz"))).isFalse();
}
static List<PathFragment> toPaths(List<String> strs) {
List<PathFragment> paths = Lists.newArrayList();
for (String s : strs) {
paths.add(PathFragment.create(s));
}
return paths;
}
static ImmutableSet<PathFragment> toPathsSet(String... strs) {
ImmutableSet.Builder<PathFragment> builder = ImmutableSet.builder();
for (String str : strs) {
builder.add(PathFragment.create(str));
}
return builder.build();
}
@Test
public void testCompareTo() throws Exception {
List<String> pathStrs = ImmutableList.of(
"", "/", "//", ".", "/./", "foo/.//bar", "foo", "/foo", "foo/bar", "foo/Bar", "Foo/bar");
List<PathFragment> paths = toPaths(pathStrs);
// First test that compareTo is self-consistent.
for (PathFragment x : paths) {
for (PathFragment y : paths) {
for (PathFragment z : paths) {
// Anti-symmetry
assertThat(-1 * Integer.signum(y.compareTo(x))).isEqualTo(Integer.signum(x.compareTo(y)));
// Transitivity
if (x.compareTo(y) > 0 && y.compareTo(z) > 0) {
assertThat(x.compareTo(z)).isGreaterThan(0);
}
// "Substitutability"
if (x.compareTo(y) == 0) {
assertThat(Integer.signum(y.compareTo(z))).isEqualTo(Integer.signum(x.compareTo(z)));
}
// Consistency with equals
assertThat(x.equals(y)).isEqualTo((x.compareTo(y) == 0));
}
}
}
// Now test that compareTo does what we expect. The exact ordering here doesn't matter much,
// but there are three things to notice: 1. absolute < relative, 2. comparison is lexicographic
// 3. repeated slashes are ignored. (PathFragment("//") prints as "/").
Collections.shuffle(paths);
Collections.sort(paths);
List<PathFragment> expectedOrder = toPaths(ImmutableList.of(
"/", "//", "/./", "/foo", "", ".", "Foo/bar", "foo", "foo/.//bar", "foo/Bar", "foo/bar"));
assertThat(paths).isEqualTo(expectedOrder);
}
@Test
public void testGetSafePathString() {
assertThat(PathFragment.create("/").getSafePathString()).isEqualTo("/");
assertThat(PathFragment.create("/abc").getSafePathString()).isEqualTo("/abc");
assertThat(PathFragment.create("").getSafePathString()).isEqualTo(".");
assertThat(PathFragment.EMPTY_FRAGMENT.getSafePathString()).isEqualTo(".");
assertThat(PathFragment.create("abc/def").getSafePathString()).isEqualTo("abc/def");
}
@Test
public void testNormalize() {
assertThat(PathFragment.create("/a/b").normalize()).isEqualTo(PathFragment.create("/a/b"));
assertThat(PathFragment.create("/a/./b").normalize()).isEqualTo(PathFragment.create("/a/b"));
assertThat(PathFragment.create("/a/../b").normalize()).isEqualTo(PathFragment.create("/b"));
assertThat(PathFragment.create("a/b").normalize()).isEqualTo(PathFragment.create("a/b"));
assertThat(PathFragment.create("a/../../b").normalize()).isEqualTo(PathFragment.create("../b"));
assertThat(PathFragment.create("a/../..").normalize()).isEqualTo(PathFragment.create(".."));
assertThat(PathFragment.create("a/../b").normalize()).isEqualTo(PathFragment.create("b"));
assertThat(PathFragment.create("a/b/../b").normalize()).isEqualTo(PathFragment.create("a/b"));
assertThat(PathFragment.create("/..").normalize()).isEqualTo(PathFragment.create("/.."));
}
@Test
public void testSerializationSimple() throws Exception {
checkSerialization("a", 91);
}
@Test
public void testSerializationAbsolute() throws Exception {
checkSerialization("/foo", 94);
}
@Test
public void testSerializationNested() throws Exception {
checkSerialization("foo/bar/baz", 101);
}
private void checkSerialization(String pathFragmentString, int expectedSize) throws Exception {
PathFragment a = PathFragment.create(pathFragmentString);
byte[] sa = TestUtils.serializeObject(a);
assertThat(sa).hasLength(expectedSize);
PathFragment a2 = (PathFragment) TestUtils.deserializeObject(sa);
assertThat(a2).isEqualTo(a);
}
}