blob: be405b5482fcd60c6033a2e7676c85d28ef9b61f [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.util;
import static com.google.common.truth.Truth.assertThat;
import com.google.common.base.Joiner;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;
import com.google.devtools.build.lib.util.FileType.HasFileType;
import com.google.devtools.build.lib.vfs.DigestHashFunction;
import com.google.devtools.build.lib.vfs.Path;
import com.google.devtools.build.lib.vfs.PathFragment;
import com.google.devtools.build.lib.vfs.inmemoryfs.InMemoryFileSystem;
import java.util.List;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
/** Test for {@link FileType} and {@link FileTypeSet}. */
@RunWith(JUnit4.class)
public class FileTypeTest {
private static final FileType CFG = FileType.of(".cfg");
private static final FileType HTML = FileType.of(".html");
private static final FileType TEXT = FileType.of(".txt");
private static final FileType CPP_SOURCE = FileType.of(".cc", ".cpp", ".cxx", ".C");
private static final FileType JAVA_SOURCE = FileType.of(".java");
private static final FileType PYTHON_SOURCE = FileType.of(".py");
private static final class HasFileTypeImpl implements HasFileType {
private final String path;
private HasFileTypeImpl(String path) {
this.path = path;
}
@Override
public String filePathForFileTypeMatcher() {
return path;
}
@Override
public String toString() {
return path;
}
}
private static void assertTrueOnWindows(boolean condition) {
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(condition).isTrue();
} else {
assertThat(condition).isFalse();
}
}
@Test
public void simpleDotMatch() {
assertThat(TEXT.matches("readme.txt")).isTrue();
}
@Test
public void doubleDotMatches() {
assertThat(TEXT.matches("read.me.txt")).isTrue();
}
@Test
public void noExtensionMatches() {
assertThat(FileType.NO_EXTENSION.matches("hello")).isTrue();
assertThat(FileType.NO_EXTENSION.matches("/path/to/hello")).isTrue();
}
@Test
public void picksLastExtension() {
assertThat(TEXT.matches("server.cfg.txt")).isTrue();
}
@Test
public void onlyExtensionStillMatches() {
assertThat(TEXT.matches(".txt")).isTrue();
assertTrueOnWindows(TEXT.matches(".TXT"));
}
@Test
public void handlesPathObjects() {
Path readme = new InMemoryFileSystem(DigestHashFunction.SHA256).getPath("/readme.txt");
Path readmeUppercase = new InMemoryFileSystem(DigestHashFunction.SHA256).getPath("/readme.TXT");
assertThat(TEXT.matches(readme)).isTrue();
assertTrueOnWindows(TEXT.matches(readmeUppercase));
}
@Test
public void handlesPathFragmentObjects() {
PathFragment readme = PathFragment.create("some/where/readme.txt");
PathFragment readmeUppercase = PathFragment.create("some/where/readme.TXT");
assertThat(TEXT.matches(readme)).isTrue();
assertTrueOnWindows(TEXT.matches(readmeUppercase));
}
@Test
public void fileTypeSetContains() {
FileTypeSet allowedTypes = FileTypeSet.of(TEXT, HTML);
assertThat(allowedTypes.matches("readme.txt")).isTrue();
assertThat(allowedTypes.matches("style.css")).isFalse();
assertTrueOnWindows(allowedTypes.matches("readme.TXT"));
}
private List<HasFileType> getArtifacts() {
return Lists.newArrayList(
new HasFileTypeImpl("Foo.java"),
new HasFileTypeImpl("bar.cc"),
new HasFileTypeImpl("baz.py"),
new HasFileTypeImpl("Foobar.CC"));
}
private String filterAll(FileType... fileTypes) {
return Joiner.on(" ").join(FileType.filter(getArtifacts(), fileTypes));
}
@Test
public void justJava() {
assertThat(filterAll(JAVA_SOURCE)).isEqualTo("Foo.java");
}
@Test
public void javaAndCpp() {
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(filterAll(JAVA_SOURCE, CPP_SOURCE)).isEqualTo("Foo.java bar.cc Foobar.CC");
} else {
assertThat(filterAll(JAVA_SOURCE, CPP_SOURCE)).isEqualTo("Foo.java bar.cc");
}
}
@Test
public void allThree() {
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(filterAll(JAVA_SOURCE, CPP_SOURCE, PYTHON_SOURCE))
.isEqualTo("Foo.java bar.cc baz.py Foobar.CC");
} else {
assertThat(filterAll(JAVA_SOURCE, CPP_SOURCE, PYTHON_SOURCE))
.isEqualTo("Foo.java bar.cc baz.py");
}
}
private HasFileType filename(final String name) {
return () -> name;
}
@Test
public void checkingSingleWithTypePredicate() throws Exception {
HasFileType item = filename("config.txt");
HasFileType itemUppercase = filename("config.TXT");
assertThat(FileType.contains(item, TEXT)).isTrue();
assertThat(FileType.contains(item, CFG)).isFalse();
assertTrueOnWindows(FileType.contains(itemUppercase, TEXT));
}
@Test
public void checkingListWithTypePredicate() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(filename("config.txt"), filename("index.HTML"), filename("README.txt"));
assertThat(FileType.contains(unfiltered, TEXT)).isTrue();
assertThat(FileType.contains(unfiltered, CFG)).isFalse();
assertTrueOnWindows(FileType.contains(unfiltered, HTML));
}
@Test
public void filteringWithTypePredicate() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(
filename("config.txt"),
filename("index.html"),
filename("README.txt"),
filename("archive.zip"),
filename("INFO.TXT"));
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(FileType.filter(unfiltered, TEXT))
.containsExactly(unfiltered.get(0), unfiltered.get(2), unfiltered.get(4))
.inOrder();
} else {
assertThat(FileType.filter(unfiltered, TEXT))
.containsExactly(unfiltered.get(0), unfiltered.get(2))
.inOrder();
}
}
@Test
public void filteringWithMatcherPredicate() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(
filename("config.txt"),
filename("index.html"),
filename("README.txt"),
filename("archive.zip"),
filename("INFO.TXT"));
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(FileType.filter(unfiltered, TEXT::matches))
.containsExactly(unfiltered.get(0), unfiltered.get(2), unfiltered.get(4))
.inOrder();
} else {
assertThat(FileType.filter(unfiltered, TEXT::matches))
.containsExactly(unfiltered.get(0), unfiltered.get(2))
.inOrder();
}
}
@Test
public void filteringWithAlwaysFalse() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(
filename("config.txt"),
filename("index.html"),
filename("binary"),
filename("archive.zip"),
filename("INFO.TXT"));
assertThat(FileType.filter(unfiltered, FileTypeSet.NO_FILE)).isEmpty();
}
@Test
public void filteringWithAlwaysTrue() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(
filename("config.txt"),
filename("index.html"),
filename("binary"),
filename("archive.zip"),
filename("INFO.TXT"));
assertThat(FileType.filter(unfiltered, FileTypeSet.ANY_FILE))
.containsExactly(
unfiltered.get(0),
unfiltered.get(1),
unfiltered.get(2),
unfiltered.get(3),
unfiltered.get(4))
.inOrder();
}
@Test
public void exclusionWithTypePredicate() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(
filename("config.txt"),
filename("index.html"),
filename("README.txt"),
filename("server.cfg"),
filename("INFO.TXT"));
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(FileType.except(unfiltered, TEXT))
.containsExactly(unfiltered.get(1), unfiltered.get(3))
.inOrder();
} else {
assertThat(FileType.except(unfiltered, TEXT))
.containsExactly(unfiltered.get(1), unfiltered.get(3), unfiltered.get(4))
.inOrder();
}
}
@Test
public void listFiltering() throws Exception {
ImmutableList<HasFileType> unfiltered =
ImmutableList.of(
filename("config.txt"),
filename("index.html"),
filename("README.txt"),
filename("server.cfg"),
filename("CLIENT.CFG"));
FileTypeSet filter = FileTypeSet.of(HTML, CFG);
if (OS.getCurrent() == OS.WINDOWS) {
assertThat(FileType.filterList(unfiltered, filter))
.containsExactly(unfiltered.get(1), unfiltered.get(3), unfiltered.get(4))
.inOrder();
} else {
assertThat(FileType.filterList(unfiltered, filter))
.containsExactly(unfiltered.get(1), unfiltered.get(3))
.inOrder();
}
}
}