aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/test/java/com/google/devtools/build/lib/packages
diff options
context:
space:
mode:
authorGravatar janakr <janakr@google.com>2018-02-16 12:16:36 -0800
committerGravatar Copybara-Service <copybara-piper@google.com>2018-02-16 12:18:38 -0800
commitcbf8c0a000e7c677316fe779d85122376752f9da (patch)
tree11ca5327710f673ed7b44b1a7dae184665318121 /src/test/java/com/google/devtools/build/lib/packages
parentcce164aed44aba1de244f0d764cd33a5cc6980b2 (diff)
Expose WorkspaceFactoryTestHelper for testing properties of the "external" package.
PiperOrigin-RevId: 186029598
Diffstat (limited to 'src/test/java/com/google/devtools/build/lib/packages')
-rw-r--r--src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTest.java120
-rw-r--r--src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTestHelper.java105
2 files changed, 121 insertions, 104 deletions
diff --git a/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTest.java b/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTest.java
index 97bfc5c2d5..934308992a 100644
--- a/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTest.java
+++ b/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTest.java
@@ -15,22 +15,8 @@
package com.google.devtools.build.lib.packages;
import static com.google.common.truth.Truth.assertThat;
-import static org.junit.Assert.fail;
-import com.google.common.collect.ImmutableList;
import com.google.devtools.build.lib.cmdline.Label;
-import com.google.devtools.build.lib.events.Event;
-import com.google.devtools.build.lib.events.StoredEventHandler;
-import com.google.devtools.build.lib.packages.Package.Builder;
-import com.google.devtools.build.lib.syntax.Mutability;
-import com.google.devtools.build.lib.syntax.ParserInputSource;
-import com.google.devtools.build.lib.syntax.SkylarkSemantics;
-import com.google.devtools.build.lib.testutil.Scratch;
-import com.google.devtools.build.lib.testutil.TestRuleClassProvider;
-import com.google.devtools.build.lib.vfs.FileSystemUtils;
-import com.google.devtools.build.lib.vfs.Path;
-import java.io.IOException;
-import java.util.List;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
@@ -44,7 +30,7 @@ public class WorkspaceFactoryTest {
@Test
public void testLoadError() throws Exception {
// WS with a syntax error: '//a' should end with .bzl.
- WorkspaceFactoryHelper helper = parse("load('//a', 'a')");
+ WorkspaceFactoryTestHelper helper = parse("load('//a', 'a')");
helper.assertLexingExceptionThrown();
assertThat(helper.getLexerError())
.contains("The label must reference a file with extension '.bzl'");
@@ -52,50 +38,48 @@ public class WorkspaceFactoryTest {
@Test
public void testWorkspaceName() throws Exception {
- WorkspaceFactoryHelper helper = parse("workspace(name = 'my_ws')");
+ WorkspaceFactoryTestHelper helper = parse("workspace(name = 'my_ws')");
assertThat(helper.getPackage().getWorkspaceName()).isEqualTo("my_ws");
}
@Test
public void testWorkspaceStartsWithNumber() throws Exception {
- WorkspaceFactoryHelper helper = parse("workspace(name = '123abc')");
+ WorkspaceFactoryTestHelper helper = parse("workspace(name = '123abc')");
assertThat(helper.getParserError()).contains("123abc is not a legal workspace name");
}
@Test
public void testWorkspaceWithIllegalCharacters() throws Exception {
- WorkspaceFactoryHelper helper = parse("workspace(name = 'a.b.c')");
+ WorkspaceFactoryTestHelper helper = parse("workspace(name = 'a.b.c')");
assertThat(helper.getParserError()).contains("a.b.c is not a legal workspace name");
}
@Test
public void testIllegalRepoName() throws Exception {
- WorkspaceFactoryHelper helper = parse("local_repository(",
- " name = 'foo/bar',",
- " path = '/foo/bar',",
- ")");
+ WorkspaceFactoryTestHelper helper =
+ parse("local_repository(", " name = 'foo/bar',", " path = '/foo/bar',", ")");
assertThat(helper.getParserError()).contains(
"local_repository rule //external:foo/bar's name field must be a legal workspace name");
}
@Test
public void testIllegalWorkspaceFunctionPosition() throws Exception {
- WorkspaceFactoryHelper helper = new WorkspaceFactoryHelper(
- false, "workspace(name = 'foo')");
+ WorkspaceFactoryTestHelper helper =
+ new WorkspaceFactoryTestHelper(false, "workspace(name = 'foo')");
assertThat(helper.getParserError()).contains(
"workspace() function should be used only at the top of the WORKSPACE file");
}
@Test
public void testRegisterExecutionPlatforms() throws Exception {
- WorkspaceFactoryHelper helper = parse("register_execution_platforms('//platform:ep1')");
+ WorkspaceFactoryTestHelper helper = parse("register_execution_platforms('//platform:ep1')");
assertThat(helper.getPackage().getRegisteredExecutionPlatformLabels())
.containsExactly(Label.parseAbsolute("//platform:ep1"));
}
@Test
public void testRegisterExecutionPlatforms_multipleLabels() throws Exception {
- WorkspaceFactoryHelper helper =
+ WorkspaceFactoryTestHelper helper =
parse("register_execution_platforms(", " '//platform:ep1',", " '//platform:ep2')");
assertThat(helper.getPackage().getRegisteredExecutionPlatformLabels())
.containsExactly(
@@ -104,7 +88,7 @@ public class WorkspaceFactoryTest {
@Test
public void testRegisterExecutionPlatforms_multipleCalls() throws Exception {
- WorkspaceFactoryHelper helper =
+ WorkspaceFactoryTestHelper helper =
parse(
"register_execution_platforms('//platform:ep1')",
"register_execution_platforms('//platform:ep2')");
@@ -115,14 +99,14 @@ public class WorkspaceFactoryTest {
@Test
public void testRegisterToolchains() throws Exception {
- WorkspaceFactoryHelper helper = parse("register_toolchains('//toolchain:tc1')");
+ WorkspaceFactoryTestHelper helper = parse("register_toolchains('//toolchain:tc1')");
assertThat(helper.getPackage().getRegisteredToolchainLabels())
.containsExactly(Label.parseAbsolute("//toolchain:tc1"));
}
@Test
public void testRegisterToolchains_multipleLabels() throws Exception {
- WorkspaceFactoryHelper helper =
+ WorkspaceFactoryTestHelper helper =
parse("register_toolchains(", " '//toolchain:tc1',", " '//toolchain:tc2')");
assertThat(helper.getPackage().getRegisteredToolchainLabels())
.containsExactly(
@@ -131,87 +115,15 @@ public class WorkspaceFactoryTest {
@Test
public void testRegisterToolchains_multipleCalls() throws Exception {
- WorkspaceFactoryHelper helper =
+ WorkspaceFactoryTestHelper helper =
parse("register_toolchains('//toolchain:tc1')", "register_toolchains('//toolchain:tc2')");
assertThat(helper.getPackage().getRegisteredToolchainLabels())
.containsExactly(
Label.parseAbsolute("//toolchain:tc1"), Label.parseAbsolute("//toolchain:tc2"));
}
- private WorkspaceFactoryHelper parse(String... args) {
- return new WorkspaceFactoryHelper(args);
+ private WorkspaceFactoryTestHelper parse(String... args) {
+ return new WorkspaceFactoryTestHelper(args);
}
- /**
- * Parses a WORKSPACE file with the given content.
- */
- private class WorkspaceFactoryHelper {
- private final Builder builder;
- private final WorkspaceFactory factory;
- private final Exception exception;
- private final ImmutableList<Event> events;
-
- public WorkspaceFactoryHelper(String... args) {
- this(true, args);
- }
-
- public WorkspaceFactoryHelper(boolean allowOverride, String... args) {
- Path root = null;
- Path workspaceFilePath = null;
- try {
- Scratch scratch = new Scratch("/");
- root = scratch.dir("/workspace");
- workspaceFilePath = scratch.file("/workspace/WORKSPACE", args);
- } catch (IOException e) {
- fail("Shouldn't happen: " + e.getMessage());
- }
- StoredEventHandler eventHandler = new StoredEventHandler();
- builder = Package.newExternalPackageBuilder(
- Package.Builder.DefaultHelper.INSTANCE, workspaceFilePath, "");
- this.factory = new WorkspaceFactory(
- builder,
- TestRuleClassProvider.getRuleClassProvider(),
- ImmutableList.<PackageFactory.EnvironmentExtension>of(),
- Mutability.create("test"),
- allowOverride,
- root,
- root);
- Exception exception = null;
- try {
- byte[] bytes =
- FileSystemUtils.readWithKnownFileSize(
- workspaceFilePath, workspaceFilePath.getFileSize());
- factory.parse(
- ParserInputSource.create(bytes, workspaceFilePath.asFragment()),
- SkylarkSemantics.DEFAULT_SEMANTICS,
- eventHandler);
- } catch (BuildFileContainsErrorsException e) {
- exception = e;
- } catch (IOException | InterruptedException e) {
- fail("Shouldn't happen: " + e.getMessage());
- }
- this.events = eventHandler.getEvents();
- this.exception = exception;
- }
-
- public Package getPackage() throws InterruptedException, NoSuchPackageException {
- return builder.build();
- }
-
- public void assertLexingExceptionThrown() {
- assertThat(exception).isNotNull();
- assertThat(exception).hasMessageThat().contains("Failed to parse /workspace/WORKSPACE");
- }
-
- public String getLexerError() {
- assertThat(events).hasSize(1);
- return events.get(0).getMessage();
- }
-
- public String getParserError() {
- List<Event> events = builder.getEvents();
- assertThat(events.size()).isGreaterThan(0);
- return events.get(0).getMessage();
- }
- }
}
diff --git a/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTestHelper.java b/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTestHelper.java
new file mode 100644
index 0000000000..712695ee61
--- /dev/null
+++ b/src/test/java/com/google/devtools/build/lib/packages/WorkspaceFactoryTestHelper.java
@@ -0,0 +1,105 @@
+// Copyright 2018 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.packages;
+
+import static com.google.common.truth.Truth.assertThat;
+import static org.junit.Assert.fail;
+
+import com.google.common.collect.ImmutableList;
+import com.google.devtools.build.lib.events.Event;
+import com.google.devtools.build.lib.events.StoredEventHandler;
+import com.google.devtools.build.lib.syntax.Mutability;
+import com.google.devtools.build.lib.syntax.ParserInputSource;
+import com.google.devtools.build.lib.syntax.SkylarkSemantics;
+import com.google.devtools.build.lib.testutil.Scratch;
+import com.google.devtools.build.lib.testutil.TestRuleClassProvider;
+import com.google.devtools.build.lib.vfs.FileSystemUtils;
+import com.google.devtools.build.lib.vfs.Path;
+import java.io.IOException;
+import java.util.List;
+
+/** Parses a WORKSPACE file with the given content. */
+class WorkspaceFactoryTestHelper {
+ private final Package.Builder builder;
+ private final Exception exception;
+ private final ImmutableList<Event> events;
+
+ WorkspaceFactoryTestHelper(String... args) {
+ this(true, args);
+ }
+
+ WorkspaceFactoryTestHelper(boolean allowOverride, String... args) {
+ this(new Scratch("/"), allowOverride, args);
+ }
+
+ WorkspaceFactoryTestHelper(Scratch scratch, boolean allowOverride, String... args) {
+ Path root = null;
+ Path workspaceFilePath = null;
+ try {
+ root = scratch.dir("/workspace");
+ workspaceFilePath = scratch.overwriteFile("/workspace/WORKSPACE", args);
+ } catch (IOException e) {
+ fail("Shouldn't happen: " + e.getMessage());
+ }
+ StoredEventHandler eventHandler = new StoredEventHandler();
+ builder =
+ Package.newExternalPackageBuilder(
+ Package.Builder.DefaultHelper.INSTANCE, workspaceFilePath, "");
+ WorkspaceFactory factory =
+ new WorkspaceFactory(
+ builder,
+ TestRuleClassProvider.getRuleClassProvider(),
+ ImmutableList.<PackageFactory.EnvironmentExtension>of(),
+ Mutability.create("test"),
+ allowOverride,
+ root,
+ root);
+ Exception exception = null;
+ try {
+ byte[] bytes =
+ FileSystemUtils.readWithKnownFileSize(workspaceFilePath, workspaceFilePath.getFileSize());
+ factory.parse(
+ ParserInputSource.create(bytes, workspaceFilePath.asFragment()),
+ SkylarkSemantics.DEFAULT_SEMANTICS,
+ eventHandler);
+ } catch (BuildFileContainsErrorsException e) {
+ exception = e;
+ } catch (IOException | InterruptedException e) {
+ fail("Shouldn't happen: " + e.getMessage());
+ }
+ this.events = eventHandler.getEvents();
+ this.exception = exception;
+ }
+
+ public Package getPackage() throws InterruptedException, NoSuchPackageException {
+ return builder.build();
+ }
+
+ public void assertLexingExceptionThrown() {
+ assertThat(exception).isNotNull();
+ assertThat(exception).hasMessageThat().contains("Failed to parse /workspace/WORKSPACE");
+ }
+
+ public String getLexerError() {
+ assertThat(events).hasSize(1);
+ return events.get(0).getMessage();
+ }
+
+ public String getParserError() {
+ List<Event> events = builder.getEvents();
+ assertThat(events.size()).isGreaterThan(0);
+ return events.get(0).getMessage();
+ }
+}