diff options
author | 2018-02-23 11:11:20 -0800 | |
---|---|---|
committer | 2018-02-23 11:13:31 -0800 | |
commit | d829236e9feee234fde3a4aed36e1349b7e9ee16 (patch) | |
tree | 5714779886376791014eda84cdb6f8cc438ba9cf /src/test/java/com | |
parent | 61aa6b7634394c7674d04da8206cf35f2aae976a (diff) |
Apply @AutoCodec to ExecutableSymlinkAction and SymlinkAction.
AbstractAction had getPrimaryInput() and getPrimaryOutput()
which is why arguments are renamed.
PiperOrigin-RevId: 186795064
Diffstat (limited to 'src/test/java/com')
3 files changed, 66 insertions, 0 deletions
diff --git a/src/test/java/com/google/devtools/build/lib/BUILD b/src/test/java/com/google/devtools/build/lib/BUILD index fad138c576..b485dcd290 100644 --- a/src/test/java/com/google/devtools/build/lib/BUILD +++ b/src/test/java/com/google/devtools/build/lib/BUILD @@ -637,6 +637,8 @@ java_test( "//src/main/java/com/google/devtools/build/lib:io", "//src/main/java/com/google/devtools/build/lib:util", "//src/main/java/com/google/devtools/build/lib/actions", + "//src/main/java/com/google/devtools/build/lib/skyframe/serialization", + "//src/main/java/com/google/devtools/build/lib/skyframe/serialization/testutils", "//src/main/java/com/google/devtools/build/lib/vfs", "//src/main/protobuf:extra_actions_base_java_proto", "//third_party:jsr305", diff --git a/src/test/java/com/google/devtools/build/lib/actions/ExecutableSymlinkActionTest.java b/src/test/java/com/google/devtools/build/lib/actions/ExecutableSymlinkActionTest.java index b1e63b6039..2fd14211e2 100644 --- a/src/test/java/com/google/devtools/build/lib/actions/ExecutableSymlinkActionTest.java +++ b/src/test/java/com/google/devtools/build/lib/actions/ExecutableSymlinkActionTest.java @@ -22,8 +22,12 @@ import com.google.common.collect.ImmutableMap; import com.google.devtools.build.lib.actions.util.DummyExecutor; import com.google.devtools.build.lib.analysis.actions.ExecutableSymlinkAction; import com.google.devtools.build.lib.exec.SingleBuildFileCache; +import com.google.devtools.build.lib.skyframe.serialization.DeserializationContext; +import com.google.devtools.build.lib.skyframe.serialization.SerializationContext; +import com.google.devtools.build.lib.skyframe.serialization.testutils.SerializationTester; import com.google.devtools.build.lib.testutil.Scratch; import com.google.devtools.build.lib.testutil.TestFileOutErr; +import com.google.devtools.build.lib.vfs.FileSystem; import com.google.devtools.build.lib.vfs.FileSystemUtils; import com.google.devtools.build.lib.vfs.Path; import org.junit.Before; @@ -112,4 +116,35 @@ public class ExecutableSymlinkActionTest { .isTrue(); } } + + @Test + public void testCodec() throws Exception { + Path file = inputRoot.getRoot().getRelative("some-file"); + FileSystemUtils.createEmptyFile(file); + file.setExecutable(/*executable=*/ false); + Artifact input = new Artifact(file, inputRoot); + Artifact output = new Artifact(outputRoot.getRoot().getRelative("some-output"), outputRoot); + ExecutableSymlinkAction action = new ExecutableSymlinkAction(NULL_ACTION_OWNER, input, output); + new SerializationTester(action) + .setWriteContextFactory( + () -> + new SerializationContext( + ImmutableMap.of(FileSystem.class, scratch.getFileSystem()))) + .setReadContextFactory( + () -> + new DeserializationContext( + ImmutableMap.of(FileSystem.class, scratch.getFileSystem()))) + .setVerificationFunction( + (in, out) -> { + ExecutableSymlinkAction inAction = (ExecutableSymlinkAction) in; + ExecutableSymlinkAction outAction = (ExecutableSymlinkAction) out; + assertThat(inAction.getPrimaryInput().getFilename()) + .isEqualTo(outAction.getPrimaryInput().getFilename()); + assertThat(inAction.getPrimaryOutput().getFilename()) + .isEqualTo(outAction.getPrimaryOutput().getFilename()); + assertThat(inAction.getOwner()).isEqualTo(outAction.getOwner()); + assertThat(inAction.getProgressMessage()).isEqualTo(outAction.getProgressMessage()); + }) + .runTests(); + } } diff --git a/src/test/java/com/google/devtools/build/lib/analysis/actions/SymlinkActionTest.java b/src/test/java/com/google/devtools/build/lib/analysis/actions/SymlinkActionTest.java index d29e5337a8..caf56bdebf 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/actions/SymlinkActionTest.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/actions/SymlinkActionTest.java @@ -24,7 +24,11 @@ import com.google.devtools.build.lib.actions.Artifact; import com.google.devtools.build.lib.actions.Executor; import com.google.devtools.build.lib.analysis.util.BuildViewTestCase; import com.google.devtools.build.lib.exec.util.TestExecutorBuilder; +import com.google.devtools.build.lib.skyframe.serialization.DeserializationContext; +import com.google.devtools.build.lib.skyframe.serialization.SerializationContext; +import com.google.devtools.build.lib.skyframe.serialization.testutils.SerializationTester; import com.google.devtools.build.lib.testutil.TestConstants; +import com.google.devtools.build.lib.vfs.FileSystem; import com.google.devtools.build.lib.vfs.FileSystemUtils; import com.google.devtools.build.lib.vfs.Path; import org.junit.Before; @@ -91,4 +95,29 @@ public class SymlinkActionTest extends BuildViewTestCase { assertThat(action.getPrimaryInput()).isEqualTo(inputArtifact); assertThat(action.getPrimaryOutput()).isEqualTo(outputArtifact); } + + @Test + public void testCodec() throws Exception { + new SerializationTester(action) + .setWriteContextFactory( + () -> + new SerializationContext( + ImmutableMap.of(FileSystem.class, scratch.getFileSystem()))) + .setReadContextFactory( + () -> + new DeserializationContext( + ImmutableMap.of(FileSystem.class, scratch.getFileSystem()))) + .setVerificationFunction( + (in, out) -> { + SymlinkAction inAction = (SymlinkAction) in; + SymlinkAction outAction = (SymlinkAction) out; + assertThat(inAction.getPrimaryInput().getFilename()) + .isEqualTo(outAction.getPrimaryInput().getFilename()); + assertThat(inAction.getPrimaryOutput().getFilename()) + .isEqualTo(outAction.getPrimaryOutput().getFilename()); + assertThat(inAction.getOwner()).isEqualTo(outAction.getOwner()); + assertThat(inAction.getProgressMessage()).isEqualTo(outAction.getProgressMessage()); + }) + .runTests(); + } } |