Damien Martin-Guillerez | f88f4d8 | 2015-09-25 13:56:55 +0000 | [diff] [blame] | 1 | // Copyright 2014 The Bazel Authors. All rights reserved. |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 2 | // |
| 3 | // Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | // you may not use this file except in compliance with the License. |
| 5 | // You may obtain a copy of the License at |
| 6 | // |
| 7 | // http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | // |
| 9 | // Unless required by applicable law or agreed to in writing, software |
| 10 | // distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | // See the License for the specific language governing permissions and |
| 13 | // limitations under the License. |
| 14 | package com.google.devtools.build.lib.vfs; |
| 15 | |
Googler | 2258b81 | 2017-12-19 12:25:43 -0800 | [diff] [blame] | 16 | import static com.google.common.collect.ImmutableList.toImmutableList; |
Ulf Adams | 795895a | 2015-03-06 15:58:35 +0000 | [diff] [blame] | 17 | import static com.google.common.truth.Truth.assertThat; |
ajurkowski | 8d7e8ff | 2021-01-13 11:10:22 -0800 | [diff] [blame] | 18 | import static com.google.devtools.build.lib.vfs.PathFragment.EMPTY_FRAGMENT; |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 19 | import static com.google.devtools.build.lib.vfs.PathFragment.create; |
michajlo | 660d17f | 2020-03-27 09:01:57 -0700 | [diff] [blame] | 20 | import static org.junit.Assert.assertThrows; |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 21 | |
| 22 | import com.google.common.collect.ImmutableList; |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 23 | import com.google.common.collect.ImmutableMap; |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 24 | import com.google.common.collect.ImmutableSet; |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 25 | import com.google.common.collect.Lists; |
| 26 | import com.google.common.testing.EqualsTester; |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 27 | import com.google.devtools.build.lib.skyframe.serialization.DeserializationContext; |
shahan | 20f35b4 | 2018-02-28 15:57:33 -0800 | [diff] [blame] | 28 | import com.google.devtools.build.lib.skyframe.serialization.testutils.SerializationTester; |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 29 | import com.google.devtools.build.lib.skyframe.serialization.testutils.TestUtils; |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 30 | import com.google.devtools.build.lib.vfs.inmemoryfs.InMemoryFileSystem; |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 31 | import com.google.protobuf.ByteString; |
Philipp Wollermann | d628b80 | 2016-10-19 12:14:38 +0000 | [diff] [blame] | 32 | import java.io.File; |
| 33 | import java.util.Collections; |
| 34 | import java.util.List; |
Laszlo Csomor | ca99bb7 | 2016-10-25 13:15:55 +0000 | [diff] [blame] | 35 | import org.junit.Test; |
| 36 | import org.junit.runner.RunWith; |
| 37 | import org.junit.runners.JUnit4; |
Philipp Wollermann | d628b80 | 2016-10-19 12:14:38 +0000 | [diff] [blame] | 38 | |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 39 | /** |
| 40 | * This class tests the functionality of the PathFragment. |
| 41 | */ |
| 42 | @RunWith(JUnit4.class) |
| 43 | public class PathFragmentTest { |
Michajlo Matijkiw | baf44c9 | 2016-06-23 21:54:05 +0000 | [diff] [blame] | 44 | |
| 45 | @Test |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 46 | public void testEqualsAndHashCode() { |
janakr | 97c0bd1 | 2020-09-08 13:19:03 -0700 | [diff] [blame] | 47 | InMemoryFileSystem filesystem = new InMemoryFileSystem(DigestHashFunction.SHA256); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 48 | |
| 49 | new EqualsTester() |
Laszlo Csomor | ca99bb7 | 2016-10-25 13:15:55 +0000 | [diff] [blame] | 50 | .addEqualityGroup( |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 51 | create("../relative/path"), |
| 52 | create("..").getRelative("relative").getRelative("path"), |
| 53 | create(new File("../relative/path").getPath())) |
| 54 | .addEqualityGroup(create("something/else")) |
| 55 | .addEqualityGroup(create("/something/else")) |
| 56 | .addEqualityGroup(create("/"), create("//////")) |
| 57 | .addEqualityGroup(create(""), PathFragment.EMPTY_FRAGMENT) |
tomlu | 6c91906 | 2018-01-11 17:32:09 -0800 | [diff] [blame] | 58 | .addEqualityGroup(filesystem.getPath("/")) // A Path object. |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 59 | .testEquals(); |
| 60 | } |
| 61 | |
| 62 | @Test |
| 63 | public void testHashCodeCache() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 64 | PathFragment relativePath = create("../relative/path"); |
| 65 | PathFragment rootPath = create("/"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 66 | |
| 67 | int oldResult = relativePath.hashCode(); |
| 68 | int rootResult = rootPath.hashCode(); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 69 | assertThat(relativePath.hashCode()).isEqualTo(oldResult); |
| 70 | assertThat(rootPath.hashCode()).isEqualTo(rootResult); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 71 | } |
| 72 | |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 73 | @Test |
| 74 | public void testRelativeTo() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 75 | assertThat(create("foo/bar/baz").relativeTo("foo").getPathString()).isEqualTo("bar/baz"); |
| 76 | assertThat(create("/foo/bar/baz").relativeTo("/foo").getPathString()).isEqualTo("bar/baz"); |
| 77 | assertThat(create("foo/bar/baz").relativeTo("foo/bar").getPathString()).isEqualTo("baz"); |
| 78 | assertThat(create("/foo/bar/baz").relativeTo("/foo/bar").getPathString()).isEqualTo("baz"); |
| 79 | assertThat(create("/foo").relativeTo("/").getPathString()).isEqualTo("foo"); |
| 80 | assertThat(create("foo").relativeTo("").getPathString()).isEqualTo("foo"); |
| 81 | assertThat(create("foo/bar").relativeTo("").getPathString()).isEqualTo("foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 82 | } |
| 83 | |
| 84 | @Test |
| 85 | public void testIsAbsolute() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 86 | assertThat(create("/absolute/test").isAbsolute()).isTrue(); |
| 87 | assertThat(create("relative/test").isAbsolute()).isFalse(); |
| 88 | assertThat(create(new File("/absolute/test").getPath()).isAbsolute()).isTrue(); |
| 89 | assertThat(create(new File("relative/test").getPath()).isAbsolute()).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 90 | } |
| 91 | |
| 92 | @Test |
| 93 | public void testIsNormalized() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 94 | assertThat(PathFragment.isNormalized("/absolute/path")).isTrue(); |
| 95 | assertThat(PathFragment.isNormalized("some//path")).isTrue(); |
| 96 | assertThat(PathFragment.isNormalized("some/./path")).isFalse(); |
| 97 | assertThat(PathFragment.isNormalized("../some/path")).isFalse(); |
| 98 | assertThat(PathFragment.isNormalized("./some/path")).isFalse(); |
| 99 | assertThat(PathFragment.isNormalized("some/path/..")).isFalse(); |
| 100 | assertThat(PathFragment.isNormalized("some/path/.")).isFalse(); |
| 101 | assertThat(PathFragment.isNormalized("some/other/../path")).isFalse(); |
| 102 | assertThat(PathFragment.isNormalized("some/other//tricky..path..")).isTrue(); |
| 103 | assertThat(PathFragment.isNormalized("/some/other//tricky..path..")).isTrue(); |
| 104 | } |
| 105 | |
| 106 | @Test |
| 107 | public void testContainsUpLevelReferences() { |
| 108 | assertThat(PathFragment.containsUplevelReferences("/absolute/path")).isFalse(); |
| 109 | assertThat(PathFragment.containsUplevelReferences("some//path")).isFalse(); |
| 110 | assertThat(PathFragment.containsUplevelReferences("some/./path")).isFalse(); |
| 111 | assertThat(PathFragment.containsUplevelReferences("../some/path")).isTrue(); |
| 112 | assertThat(PathFragment.containsUplevelReferences("./some/path")).isFalse(); |
| 113 | assertThat(PathFragment.containsUplevelReferences("some/path/..")).isTrue(); |
| 114 | assertThat(PathFragment.containsUplevelReferences("some/path/.")).isFalse(); |
| 115 | assertThat(PathFragment.containsUplevelReferences("some/other/../path")).isTrue(); |
| 116 | assertThat(PathFragment.containsUplevelReferences("some/other//tricky..path..")).isFalse(); |
| 117 | assertThat(PathFragment.containsUplevelReferences("/some/other//tricky..path..")).isFalse(); |
| 118 | |
| 119 | // Normalization cannot remove leading uplevel references, so this will be true |
| 120 | assertThat(create("../some/path").containsUplevelReferences()).isTrue(); |
| 121 | // Normalization will remove these, so no uplevel references left |
| 122 | assertThat(create("some/path/..").containsUplevelReferences()).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 123 | } |
| 124 | |
| 125 | @Test |
| 126 | public void testRootNodeReturnsRootString() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 127 | PathFragment rootFragment = create("/"); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 128 | assertThat(rootFragment.getPathString()).isEqualTo("/"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 129 | } |
| 130 | |
| 131 | @Test |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 132 | public void testGetRelative() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 133 | assertThat(create("a").getRelative("b").getPathString()).isEqualTo("a/b"); |
| 134 | assertThat(create("a/b").getRelative("c/d").getPathString()).isEqualTo("a/b/c/d"); |
| 135 | assertThat(create("c/d").getRelative("/a/b").getPathString()).isEqualTo("/a/b"); |
| 136 | assertThat(create("a").getRelative("").getPathString()).isEqualTo("a"); |
| 137 | assertThat(create("/").getRelative("").getPathString()).isEqualTo("/"); |
| 138 | assertThat(create("a/b").getRelative("../foo").getPathString()).isEqualTo("a/foo"); |
| 139 | assertThat(create("/a/b").getRelative("../foo").getPathString()).isEqualTo("/a/foo"); |
| 140 | |
| 141 | // Make sure any fast path of PathFragment#getRelative(PathFragment) works |
| 142 | assertThat(create("a/b").getRelative(create("../foo")).getPathString()).isEqualTo("a/foo"); |
| 143 | assertThat(create("/a/b").getRelative(create("../foo")).getPathString()).isEqualTo("/a/foo"); |
| 144 | |
| 145 | // Make sure any fast path of PathFragment#getRelative(PathFragment) works |
| 146 | assertThat(create("c/d").getRelative(create("/a/b")).getPathString()).isEqualTo("/a/b"); |
| 147 | |
| 148 | // Test normalization |
| 149 | assertThat(create("a").getRelative(".").getPathString()).isEqualTo("a"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 150 | } |
| 151 | |
| 152 | @Test |
nharmata | 90750e6 | 2018-03-15 09:35:48 -0700 | [diff] [blame] | 153 | public void testIsNormalizedRelativePath() { |
| 154 | assertThat(PathFragment.isNormalizedRelativePath("/a")).isFalse(); |
| 155 | assertThat(PathFragment.isNormalizedRelativePath("a///b")).isFalse(); |
| 156 | assertThat(PathFragment.isNormalizedRelativePath("../a")).isFalse(); |
| 157 | assertThat(PathFragment.isNormalizedRelativePath("a/../b")).isFalse(); |
| 158 | assertThat(PathFragment.isNormalizedRelativePath("a/b")).isTrue(); |
| 159 | assertThat(PathFragment.isNormalizedRelativePath("ab")).isTrue(); |
| 160 | } |
| 161 | |
| 162 | @Test |
| 163 | public void testContainsSeparator() { |
| 164 | assertThat(PathFragment.containsSeparator("/a")).isTrue(); |
| 165 | assertThat(PathFragment.containsSeparator("a///b")).isTrue(); |
| 166 | assertThat(PathFragment.containsSeparator("../a")).isTrue(); |
| 167 | assertThat(PathFragment.containsSeparator("a/../b")).isTrue(); |
| 168 | assertThat(PathFragment.containsSeparator("a/b")).isTrue(); |
| 169 | assertThat(PathFragment.containsSeparator("ab")).isFalse(); |
| 170 | } |
| 171 | |
| 172 | @Test |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 173 | public void testGetChildWorks() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 174 | PathFragment pf = create("../some/path"); |
| 175 | assertThat(pf.getChild("hi")).isEqualTo(create("../some/path/hi")); |
janakr | d1ad61c | 2020-11-11 07:13:40 -0800 | [diff] [blame] | 176 | assertThat(pf.getChild("h\\i")).isEqualTo(create("../some/path/h\\i")); |
| 177 | assertThat(create("../some/path").getChild(".hi")).isEqualTo(create("../some/path/.hi")); |
| 178 | assertThat(create("../some/path").getChild("..hi")).isEqualTo(create("../some/path/..hi")); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 179 | } |
| 180 | |
| 181 | @Test |
| 182 | public void testGetChildRejectsInvalidBaseNames() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 183 | PathFragment pf = create("../some/path"); |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 184 | assertThrows(IllegalArgumentException.class, () -> pf.getChild(".")); |
| 185 | assertThrows(IllegalArgumentException.class, () -> pf.getChild("..")); |
| 186 | assertThrows(IllegalArgumentException.class, () -> pf.getChild("x/y")); |
| 187 | assertThrows(IllegalArgumentException.class, () -> pf.getChild("/y")); |
| 188 | assertThrows(IllegalArgumentException.class, () -> pf.getChild("y/")); |
| 189 | assertThrows(IllegalArgumentException.class, () -> pf.getChild("")); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 190 | } |
| 191 | |
| 192 | @Test |
| 193 | public void testEmptyPathToEmptyPath() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 194 | assertThat(create("/").getPathString()).isEqualTo("/"); |
| 195 | assertThat(create("").getPathString()).isEqualTo(""); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 196 | } |
| 197 | |
| 198 | @Test |
| 199 | public void testRedundantSlashes() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 200 | assertThat(create("///").getPathString()).isEqualTo("/"); |
| 201 | assertThat(create("/foo///bar").getPathString()).isEqualTo("/foo/bar"); |
| 202 | assertThat(create("////foo//bar").getPathString()).isEqualTo("/foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 203 | } |
| 204 | |
| 205 | @Test |
| 206 | public void testSimpleNameToSimpleName() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 207 | assertThat(create("/foo").getPathString()).isEqualTo("/foo"); |
| 208 | assertThat(create("foo").getPathString()).isEqualTo("foo"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 209 | } |
| 210 | |
| 211 | @Test |
| 212 | public void testSimplePathToSimplePath() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 213 | assertThat(create("/foo/bar").getPathString()).isEqualTo("/foo/bar"); |
| 214 | assertThat(create("foo/bar").getPathString()).isEqualTo("foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 215 | } |
| 216 | |
| 217 | @Test |
| 218 | public void testStripsTrailingSlash() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 219 | assertThat(create("/foo/bar/").getPathString()).isEqualTo("/foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 220 | } |
| 221 | |
| 222 | @Test |
| 223 | public void testGetParentDirectory() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 224 | PathFragment fooBarWiz = create("foo/bar/wiz"); |
| 225 | PathFragment fooBar = create("foo/bar"); |
| 226 | PathFragment foo = create("foo"); |
| 227 | PathFragment empty = create(""); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 228 | assertThat(fooBarWiz.getParentDirectory()).isEqualTo(fooBar); |
| 229 | assertThat(fooBar.getParentDirectory()).isEqualTo(foo); |
| 230 | assertThat(foo.getParentDirectory()).isEqualTo(empty); |
| 231 | assertThat(empty.getParentDirectory()).isNull(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 232 | |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 233 | PathFragment fooBarWizAbs = create("/foo/bar/wiz"); |
| 234 | PathFragment fooBarAbs = create("/foo/bar"); |
| 235 | PathFragment fooAbs = create("/foo"); |
| 236 | PathFragment rootAbs = create("/"); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 237 | assertThat(fooBarWizAbs.getParentDirectory()).isEqualTo(fooBarAbs); |
| 238 | assertThat(fooBarAbs.getParentDirectory()).isEqualTo(fooAbs); |
| 239 | assertThat(fooAbs.getParentDirectory()).isEqualTo(rootAbs); |
| 240 | assertThat(rootAbs.getParentDirectory()).isNull(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 241 | } |
Michajlo Matijkiw | baf44c9 | 2016-06-23 21:54:05 +0000 | [diff] [blame] | 242 | |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 243 | @Test |
| 244 | public void testSegmentsCount() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 245 | assertThat(create("foo/bar").segmentCount()).isEqualTo(2); |
| 246 | assertThat(create("/foo/bar").segmentCount()).isEqualTo(2); |
| 247 | assertThat(create("foo//bar").segmentCount()).isEqualTo(2); |
| 248 | assertThat(create("/foo//bar").segmentCount()).isEqualTo(2); |
| 249 | assertThat(create("foo/").segmentCount()).isEqualTo(1); |
| 250 | assertThat(create("/foo/").segmentCount()).isEqualTo(1); |
| 251 | assertThat(create("foo").segmentCount()).isEqualTo(1); |
| 252 | assertThat(create("/foo").segmentCount()).isEqualTo(1); |
| 253 | assertThat(create("/").segmentCount()).isEqualTo(0); |
| 254 | assertThat(create("").segmentCount()).isEqualTo(0); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 255 | } |
| 256 | |
| 257 | |
| 258 | @Test |
| 259 | public void testGetSegment() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 260 | assertThat(create("foo/bar").getSegment(0)).isEqualTo("foo"); |
| 261 | assertThat(create("foo/bar").getSegment(1)).isEqualTo("bar"); |
| 262 | assertThat(create("/foo/bar").getSegment(0)).isEqualTo("foo"); |
| 263 | assertThat(create("/foo/bar").getSegment(1)).isEqualTo("bar"); |
| 264 | assertThat(create("foo/").getSegment(0)).isEqualTo("foo"); |
| 265 | assertThat(create("/foo/").getSegment(0)).isEqualTo("foo"); |
| 266 | assertThat(create("foo").getSegment(0)).isEqualTo("foo"); |
| 267 | assertThat(create("/foo").getSegment(0)).isEqualTo("foo"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 268 | } |
| 269 | |
| 270 | @Test |
jhorvitz | 6034795 | 2021-02-18 10:05:05 -0800 | [diff] [blame] | 271 | public void segments() { |
| 272 | assertThat(create("/this/is/a/path").segments()) |
| 273 | .containsExactly("this", "is", "a", "path") |
| 274 | .inOrder(); |
| 275 | } |
| 276 | |
| 277 | @Test |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 278 | public void testBasename() throws Exception { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 279 | assertThat(create("foo/bar").getBaseName()).isEqualTo("bar"); |
| 280 | assertThat(create("/foo/bar").getBaseName()).isEqualTo("bar"); |
| 281 | assertThat(create("foo/").getBaseName()).isEqualTo("foo"); |
| 282 | assertThat(create("/foo/").getBaseName()).isEqualTo("foo"); |
| 283 | assertThat(create("foo").getBaseName()).isEqualTo("foo"); |
| 284 | assertThat(create("/foo").getBaseName()).isEqualTo("foo"); |
| 285 | assertThat(create("/").getBaseName()).isEmpty(); |
| 286 | assertThat(create("").getBaseName()).isEmpty(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 287 | } |
| 288 | |
Paul Roberts | 8c443ef | 2016-10-18 02:04:25 +0000 | [diff] [blame] | 289 | @Test |
| 290 | public void testFileExtension() throws Exception { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 291 | assertThat(create("foo.bar").getFileExtension()).isEqualTo("bar"); |
| 292 | assertThat(create("foo.barr").getFileExtension()).isEqualTo("barr"); |
| 293 | assertThat(create("foo.b").getFileExtension()).isEqualTo("b"); |
| 294 | assertThat(create("foo.").getFileExtension()).isEmpty(); |
| 295 | assertThat(create("foo").getFileExtension()).isEmpty(); |
| 296 | assertThat(create(".").getFileExtension()).isEmpty(); |
| 297 | assertThat(create("").getFileExtension()).isEmpty(); |
| 298 | assertThat(create("foo/bar.baz").getFileExtension()).isEqualTo("baz"); |
| 299 | assertThat(create("foo.bar.baz").getFileExtension()).isEqualTo("baz"); |
| 300 | assertThat(create("foo.bar/baz").getFileExtension()).isEmpty(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 301 | } |
| 302 | |
| 303 | @Test |
| 304 | public void testReplaceName() throws Exception { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 305 | assertThat(create("foo/bar").replaceName("baz").getPathString()).isEqualTo("foo/baz"); |
| 306 | assertThat(create("/foo/bar").replaceName("baz").getPathString()).isEqualTo("/foo/baz"); |
| 307 | assertThat(create("foo/bar").replaceName("").getPathString()).isEqualTo("foo"); |
| 308 | assertThat(create("foo/").replaceName("baz").getPathString()).isEqualTo("baz"); |
| 309 | assertThat(create("/foo/").replaceName("baz").getPathString()).isEqualTo("/baz"); |
| 310 | assertThat(create("foo").replaceName("baz").getPathString()).isEqualTo("baz"); |
| 311 | assertThat(create("/foo").replaceName("baz").getPathString()).isEqualTo("/baz"); |
| 312 | assertThat(create("/").replaceName("baz")).isNull(); |
| 313 | assertThat(create("/").replaceName("")).isNull(); |
| 314 | assertThat(create("").replaceName("baz")).isNull(); |
| 315 | assertThat(create("").replaceName("")).isNull(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 316 | |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 317 | assertThat(create("foo/bar").replaceName("bar/baz").getPathString()).isEqualTo("foo/bar/baz"); |
| 318 | assertThat(create("foo/bar").replaceName("bar/baz/").getPathString()).isEqualTo("foo/bar/baz"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 319 | |
| 320 | // Absolute path arguments will clobber the original path. |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 321 | assertThat(create("foo/bar").replaceName("/absolute").getPathString()).isEqualTo("/absolute"); |
| 322 | assertThat(create("foo/bar").replaceName("/").getPathString()).isEqualTo("/"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 323 | } |
| 324 | @Test |
| 325 | public void testSubFragment() throws Exception { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 326 | assertThat(create("/foo/bar/baz").subFragment(0, 3).getPathString()).isEqualTo("/foo/bar/baz"); |
| 327 | assertThat(create("foo/bar/baz").subFragment(0, 3).getPathString()).isEqualTo("foo/bar/baz"); |
| 328 | assertThat(create("/foo/bar/baz").subFragment(0, 2).getPathString()).isEqualTo("/foo/bar"); |
| 329 | assertThat(create("/foo/bar/baz").subFragment(1, 3).getPathString()).isEqualTo("bar/baz"); |
| 330 | assertThat(create("/foo/bar/baz").subFragment(0, 1).getPathString()).isEqualTo("/foo"); |
| 331 | assertThat(create("/foo/bar/baz").subFragment(1, 2).getPathString()).isEqualTo("bar"); |
| 332 | assertThat(create("/foo/bar/baz").subFragment(2, 3).getPathString()).isEqualTo("baz"); |
| 333 | assertThat(create("/foo/bar/baz").subFragment(0, 0).getPathString()).isEqualTo("/"); |
| 334 | assertThat(create("foo/bar/baz").subFragment(0, 0).getPathString()).isEqualTo(""); |
| 335 | assertThat(create("foo/bar/baz").subFragment(1, 1).getPathString()).isEqualTo(""); |
| 336 | |
| 337 | assertThat(create("/foo/bar/baz").subFragment(0).getPathString()).isEqualTo("/foo/bar/baz"); |
| 338 | assertThat(create("foo/bar/baz").subFragment(0).getPathString()).isEqualTo("foo/bar/baz"); |
| 339 | assertThat(create("/foo/bar/baz").subFragment(1).getPathString()).isEqualTo("bar/baz"); |
| 340 | assertThat(create("foo/bar/baz").subFragment(1).getPathString()).isEqualTo("bar/baz"); |
| 341 | assertThat(create("foo/bar/baz").subFragment(2).getPathString()).isEqualTo("baz"); |
| 342 | assertThat(create("foo/bar/baz").subFragment(3).getPathString()).isEqualTo(""); |
| 343 | |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 344 | assertThrows(IndexOutOfBoundsException.class, () -> create("foo/bar/baz").subFragment(3, 2)); |
| 345 | assertThrows(IndexOutOfBoundsException.class, () -> create("foo/bar/baz").subFragment(4, 4)); |
| 346 | assertThrows(IndexOutOfBoundsException.class, () -> create("foo/bar/baz").subFragment(3, 2)); |
| 347 | assertThrows(IndexOutOfBoundsException.class, () -> create("foo/bar/baz").subFragment(4)); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 348 | } |
| 349 | |
| 350 | @Test |
| 351 | public void testStartsWith() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 352 | PathFragment foobar = create("/foo/bar"); |
| 353 | PathFragment foobarRelative = create("foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 354 | |
| 355 | // (path, prefix) => true |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 356 | assertThat(foobar.startsWith(foobar)).isTrue(); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 357 | assertThat(foobar.startsWith(create("/"))).isTrue(); |
| 358 | assertThat(foobar.startsWith(create("/foo"))).isTrue(); |
| 359 | assertThat(foobar.startsWith(create("/foo/"))).isTrue(); |
| 360 | assertThat(foobar.startsWith(create("/foo/bar/"))).isTrue(); // Includes trailing slash. |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 361 | |
| 362 | // (prefix, path) => false |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 363 | assertThat(create("/foo").startsWith(foobar)).isFalse(); |
| 364 | assertThat(create("/").startsWith(foobar)).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 365 | |
| 366 | // (absolute, relative) => false |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 367 | assertThat(foobar.startsWith(foobarRelative)).isFalse(); |
| 368 | assertThat(foobarRelative.startsWith(foobar)).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 369 | |
| 370 | // (relative path, relative prefix) => true |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 371 | assertThat(foobarRelative.startsWith(foobarRelative)).isTrue(); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 372 | assertThat(foobarRelative.startsWith(create("foo"))).isTrue(); |
| 373 | assertThat(foobarRelative.startsWith(create(""))).isTrue(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 374 | |
| 375 | // (path, sibling) => false |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 376 | assertThat(create("/foo/wiz").startsWith(foobar)).isFalse(); |
| 377 | assertThat(foobar.startsWith(create("/foo/wiz"))).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 378 | } |
| 379 | |
| 380 | @Test |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 381 | public void testCheckAllPathsStartWithButAreNotEqualTo() { |
| 382 | // Check passes: |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 383 | PathFragment.checkAllPathsAreUnder(toPathsSet("a/b", "a/c"), create("a")); |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 384 | |
| 385 | // Check trivially passes: |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 386 | PathFragment.checkAllPathsAreUnder(ImmutableList.<PathFragment>of(), create("a")); |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 387 | |
| 388 | // Check fails when some path does not start with startingWithPath: |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 389 | assertThrows( |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 390 | IllegalArgumentException.class, |
| 391 | () -> PathFragment.checkAllPathsAreUnder(toPathsSet("a/b", "b/c"), create("a"))); |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 392 | |
| 393 | // Check fails when some path is equal to startingWithPath: |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 394 | assertThrows( |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 395 | IllegalArgumentException.class, |
| 396 | () -> PathFragment.checkAllPathsAreUnder(toPathsSet("a/b", "a"), create("a"))); |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 397 | } |
| 398 | |
| 399 | @Test |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 400 | public void testEndsWith() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 401 | PathFragment foobar = create("/foo/bar"); |
| 402 | PathFragment foobarRelative = create("foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 403 | |
| 404 | // (path, suffix) => true |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 405 | assertThat(foobar.endsWith(foobar)).isTrue(); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 406 | assertThat(foobar.endsWith(create("bar"))).isTrue(); |
| 407 | assertThat(foobar.endsWith(create("foo/bar"))).isTrue(); |
| 408 | assertThat(foobar.endsWith(create("/foo/bar"))).isTrue(); |
| 409 | assertThat(foobar.endsWith(create("/bar"))).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 410 | |
| 411 | // (prefix, path) => false |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 412 | assertThat(create("/foo").endsWith(foobar)).isFalse(); |
| 413 | assertThat(create("/").endsWith(foobar)).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 414 | |
| 415 | // (suffix, path) => false |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 416 | assertThat(create("/bar").endsWith(foobar)).isFalse(); |
| 417 | assertThat(create("bar").endsWith(foobar)).isFalse(); |
| 418 | assertThat(create("").endsWith(foobar)).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 419 | |
| 420 | // (absolute, relative) => true |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 421 | assertThat(foobar.endsWith(foobarRelative)).isTrue(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 422 | |
| 423 | // (relative, absolute) => false |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 424 | assertThat(foobarRelative.endsWith(foobar)).isFalse(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 425 | |
| 426 | // (relative path, relative prefix) => true |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 427 | assertThat(foobarRelative.endsWith(foobarRelative)).isTrue(); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 428 | assertThat(foobarRelative.endsWith(create("bar"))).isTrue(); |
| 429 | assertThat(foobarRelative.endsWith(create(""))).isTrue(); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 430 | |
| 431 | // (path, sibling) => false |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 432 | assertThat(create("/foo/wiz").endsWith(foobar)).isFalse(); |
| 433 | assertThat(foobar.endsWith(create("/foo/wiz"))).isFalse(); |
| 434 | } |
| 435 | |
| 436 | @Test |
| 437 | public void testToRelative() { |
| 438 | assertThat(create("/foo/bar").toRelative()).isEqualTo(create("foo/bar")); |
| 439 | assertThat(create("/").toRelative()).isEqualTo(create("")); |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 440 | assertThrows(IllegalArgumentException.class, () -> create("foo").toRelative()); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 441 | } |
| 442 | |
| 443 | @Test |
| 444 | public void testGetDriveStr() { |
| 445 | assertThat(create("/foo/bar").getDriveStr()).isEqualTo("/"); |
| 446 | assertThat(create("/").getDriveStr()).isEqualTo("/"); |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 447 | assertThrows(IllegalArgumentException.class, () -> create("foo").getDriveStr()); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 448 | } |
| 449 | |
| 450 | static List<PathFragment> toPaths(List<String> strs) { |
| 451 | List<PathFragment> paths = Lists.newArrayList(); |
| 452 | for (String s : strs) { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 453 | paths.add(create(s)); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 454 | } |
| 455 | return paths; |
| 456 | } |
| 457 | |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 458 | static ImmutableSet<PathFragment> toPathsSet(String... strs) { |
| 459 | ImmutableSet.Builder<PathFragment> builder = ImmutableSet.builder(); |
| 460 | for (String str : strs) { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 461 | builder.add(create(str)); |
Mark Schaller | b815432 | 2015-06-22 16:02:24 +0000 | [diff] [blame] | 462 | } |
| 463 | return builder.build(); |
| 464 | } |
| 465 | |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 466 | @Test |
| 467 | public void testCompareTo() throws Exception { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 468 | List<String> pathStrs = |
| 469 | ImmutableList.of( |
| 470 | "", |
| 471 | "/", |
| 472 | "foo", |
| 473 | "/foo", |
| 474 | "foo/bar", |
| 475 | "foo.bar", |
| 476 | "foo/bar.baz", |
| 477 | "foo/bar/baz", |
| 478 | "foo/barfile", |
| 479 | "foo/Bar", |
| 480 | "Foo/bar"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 481 | List<PathFragment> paths = toPaths(pathStrs); |
| 482 | // First test that compareTo is self-consistent. |
| 483 | for (PathFragment x : paths) { |
| 484 | for (PathFragment y : paths) { |
| 485 | for (PathFragment z : paths) { |
| 486 | // Anti-symmetry |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 487 | assertThat(-1 * Integer.signum(y.compareTo(x))).isEqualTo(Integer.signum(x.compareTo(y))); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 488 | // Transitivity |
| 489 | if (x.compareTo(y) > 0 && y.compareTo(z) > 0) { |
Googler | 2fa3ccf | 2015-11-10 14:30:39 +0000 | [diff] [blame] | 490 | assertThat(x.compareTo(z)).isGreaterThan(0); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 491 | } |
| 492 | // "Substitutability" |
| 493 | if (x.compareTo(y) == 0) { |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 494 | assertThat(Integer.signum(y.compareTo(z))).isEqualTo(Integer.signum(x.compareTo(z))); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 495 | } |
| 496 | // Consistency with equals |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 497 | assertThat(x.equals(y)).isEqualTo((x.compareTo(y) == 0)); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 498 | } |
| 499 | } |
| 500 | } |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 501 | // Now test that compareTo does what we expect. The exact ordering here doesn't matter much. |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 502 | Collections.shuffle(paths); |
| 503 | Collections.sort(paths); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 504 | List<PathFragment> expectedOrder = |
| 505 | toPaths( |
| 506 | ImmutableList.of( |
| 507 | "", |
| 508 | "/", |
| 509 | "/foo", |
| 510 | "Foo/bar", |
| 511 | "foo", |
| 512 | "foo.bar", |
| 513 | "foo/Bar", |
| 514 | "foo/bar", |
| 515 | "foo/bar.baz", |
| 516 | "foo/bar/baz", |
| 517 | "foo/barfile")); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 518 | assertThat(paths).isEqualTo(expectedOrder); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 519 | } |
| 520 | |
| 521 | @Test |
| 522 | public void testGetSafePathString() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 523 | assertThat(create("/").getSafePathString()).isEqualTo("/"); |
| 524 | assertThat(create("/abc").getSafePathString()).isEqualTo("/abc"); |
| 525 | assertThat(create("").getSafePathString()).isEqualTo("."); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 526 | assertThat(PathFragment.EMPTY_FRAGMENT.getSafePathString()).isEqualTo("."); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 527 | assertThat(create("abc/def").getSafePathString()).isEqualTo("abc/def"); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 528 | } |
Michajlo Matijkiw | baf44c9 | 2016-06-23 21:54:05 +0000 | [diff] [blame] | 529 | |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 530 | @Test |
| 531 | public void testNormalize() { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 532 | assertThat(create("/a/b")).isEqualTo(create("/a/b")); |
| 533 | assertThat(create("/a/./b")).isEqualTo(create("/a/b")); |
| 534 | assertThat(create("/a/../b")).isEqualTo(create("/b")); |
| 535 | assertThat(create("a/b")).isEqualTo(create("a/b")); |
| 536 | assertThat(create("a/../../b")).isEqualTo(create("../b")); |
| 537 | assertThat(create("a/../..")).isEqualTo(create("..")); |
| 538 | assertThat(create("a/../b")).isEqualTo(create("b")); |
| 539 | assertThat(create("a/b/../b")).isEqualTo(create("a/b")); |
| 540 | assertThat(create("/..")).isEqualTo(create("/..")); |
| 541 | assertThat(create("..")).isEqualTo(create("..")); |
| 542 | } |
| 543 | |
| 544 | @Test |
| 545 | public void testSegments() { |
| 546 | assertThat(create("").segmentCount()).isEqualTo(0); |
| 547 | assertThat(create("a").segmentCount()).isEqualTo(1); |
| 548 | assertThat(create("a/b").segmentCount()).isEqualTo(2); |
| 549 | assertThat(create("a/b/c").segmentCount()).isEqualTo(3); |
| 550 | assertThat(create("/").segmentCount()).isEqualTo(0); |
| 551 | assertThat(create("/a").segmentCount()).isEqualTo(1); |
| 552 | assertThat(create("/a/b").segmentCount()).isEqualTo(2); |
| 553 | assertThat(create("/a/b/c").segmentCount()).isEqualTo(3); |
| 554 | |
jhorvitz | c4bdbe0 | 2021-02-26 08:11:03 -0800 | [diff] [blame^] | 555 | assertThat(create("").splitToListOfSegments()).isEmpty(); |
| 556 | assertThat(create("a").splitToListOfSegments()).containsExactly("a").inOrder(); |
| 557 | assertThat(create("a/b").splitToListOfSegments()).containsExactly("a", "b").inOrder(); |
| 558 | assertThat(create("a/b/c").splitToListOfSegments()).containsExactly("a", "b", "c").inOrder(); |
| 559 | assertThat(create("/").splitToListOfSegments()).isEmpty(); |
| 560 | assertThat(create("/a").splitToListOfSegments()).containsExactly("a").inOrder(); |
| 561 | assertThat(create("/a/b").splitToListOfSegments()).containsExactly("a", "b").inOrder(); |
| 562 | assertThat(create("/a/b/c").splitToListOfSegments()).containsExactly("a", "b", "c").inOrder(); |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 563 | |
| 564 | assertThat(create("a").getSegment(0)).isEqualTo("a"); |
| 565 | assertThat(create("a/b").getSegment(0)).isEqualTo("a"); |
| 566 | assertThat(create("a/b").getSegment(1)).isEqualTo("b"); |
| 567 | assertThat(create("a/b/c").getSegment(2)).isEqualTo("c"); |
| 568 | assertThat(create("/a").getSegment(0)).isEqualTo("a"); |
| 569 | assertThat(create("/a/b").getSegment(0)).isEqualTo("a"); |
| 570 | assertThat(create("/a/b").getSegment(1)).isEqualTo("b"); |
| 571 | assertThat(create("/a/b/c").getSegment(2)).isEqualTo("c"); |
| 572 | |
jcater | b0c7ee5 | 2019-05-02 12:33:13 -0700 | [diff] [blame] | 573 | assertThrows(IllegalArgumentException.class, () -> create("").getSegment(0)); |
| 574 | assertThrows(IllegalArgumentException.class, () -> create("a/b").getSegment(2)); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 575 | } |
| 576 | |
| 577 | @Test |
Googler | 2258b81 | 2017-12-19 12:25:43 -0800 | [diff] [blame] | 578 | public void testCodec() throws Exception { |
shahan | 20f35b4 | 2018-02-28 15:57:33 -0800 | [diff] [blame] | 579 | new SerializationTester( |
Googler | 2258b81 | 2017-12-19 12:25:43 -0800 | [diff] [blame] | 580 | ImmutableList.of("", "a", "/foo", "foo/bar/baz", "/a/path/fragment/with/lots/of/parts") |
| 581 | .stream() |
| 582 | .map(PathFragment::create) |
| 583 | .collect(toImmutableList())) |
shahan | 20f35b4 | 2018-02-28 15:57:33 -0800 | [diff] [blame] | 584 | .runTests(); |
Googler | 2258b81 | 2017-12-19 12:25:43 -0800 | [diff] [blame] | 585 | } |
| 586 | |
| 587 | @Test |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 588 | public void testSerializationSimple() throws Exception { |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 589 | checkSerialization("a", 6); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 590 | } |
| 591 | |
| 592 | @Test |
| 593 | public void testSerializationAbsolute() throws Exception { |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 594 | checkSerialization("/foo", 9); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 595 | } |
| 596 | |
| 597 | @Test |
| 598 | public void testSerializationNested() throws Exception { |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 599 | checkSerialization("foo/bar/baz", 16); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 600 | } |
| 601 | |
| 602 | private void checkSerialization(String pathFragmentString, int expectedSize) throws Exception { |
tomlu | a729b9b | 2018-02-08 15:32:00 -0800 | [diff] [blame] | 603 | PathFragment a = create(pathFragmentString); |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 604 | ByteString sa = TestUtils.toBytes(a, ImmutableMap.of()); |
| 605 | assertThat(sa.size()).isEqualTo(expectedSize); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 606 | |
janakr | 5b02f72 | 2020-04-29 08:06:46 -0700 | [diff] [blame] | 607 | PathFragment a2 = |
| 608 | (PathFragment) TestUtils.fromBytes(new DeserializationContext(ImmutableMap.of()), sa); |
lberki | aea56b3 | 2017-05-30 12:35:33 +0200 | [diff] [blame] | 609 | assertThat(a2).isEqualTo(a); |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 610 | } |
ajurkowski | 8d7e8ff | 2021-01-13 11:10:22 -0800 | [diff] [blame] | 611 | |
| 612 | @Test |
| 613 | public void containsUplevelReference_emptyPath_returnsFalse() { |
| 614 | assertThat(EMPTY_FRAGMENT.containsUplevelReferences()).isFalse(); |
| 615 | } |
| 616 | |
| 617 | @Test |
| 618 | public void containsUplevelReference_uplevelOnlyPath_returnsTrue() { |
| 619 | PathFragment pathFragment = create(".."); |
| 620 | assertThat(pathFragment.containsUplevelReferences()).isTrue(); |
| 621 | } |
| 622 | |
| 623 | @Test |
| 624 | public void containsUplevelReferences_firstSegmentStartingWithDotDot_returnsFalse() { |
| 625 | PathFragment pathFragment = create("..file"); |
| 626 | assertThat(pathFragment.containsUplevelReferences()).isFalse(); |
| 627 | } |
| 628 | |
| 629 | @Test |
| 630 | public void containsUplevelReferences_startsWithUplevelReference_returnsTrue() { |
| 631 | PathFragment pathFragment = create("../file"); |
| 632 | assertThat(pathFragment.containsUplevelReferences()).isTrue(); |
| 633 | } |
| 634 | |
| 635 | @Test |
| 636 | public void containsUplevelReferences_uplevelReferenceMidPath_normalizesAndReturnsFalse() { |
| 637 | PathFragment pathFragment = create("a/../b"); |
| 638 | |
| 639 | assertThat(pathFragment.containsUplevelReferences()).isFalse(); |
| 640 | assertThat(pathFragment.getPathString()).isEqualTo("b"); |
| 641 | } |
| 642 | |
| 643 | @Test |
| 644 | public void containsUplevelReferenes_uplevelReferenceMidGlobalPath_normalizesAndReturnsFalse() { |
| 645 | PathFragment pathFragment = create("/dir1/dir2/../file"); |
| 646 | |
| 647 | assertThat(pathFragment.containsUplevelReferences()).isFalse(); |
| 648 | assertThat(pathFragment.getPathString()).isEqualTo("/dir1/file"); |
| 649 | } |
Han-Wen Nienhuys | d08b27f | 2015-02-25 16:45:20 +0100 | [diff] [blame] | 650 | } |