aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/test
diff options
context:
space:
mode:
authorGravatar felly <felly@google.com>2018-08-10 08:36:40 -0700
committerGravatar Copybara-Service <copybara-piper@google.com>2018-08-10 08:38:04 -0700
commit9374ecf94ce44e8bc56e68678cb512abf4cf9ce2 (patch)
tree7ad91bd14bd961b2dbb908b7f762b55fa5f2eb8d /src/test
parent6300c7eb70622b55bbc5f73ec1ffe8116d55c9cd (diff)
Automated rollback of commit 39974a43abdd32e3a1acbc7da945b08da9983e4e.
*** Reason for rollback *** b/112458627 *** Original change description *** Allow skyframe-aware actions to pass partial results through ActionExecutionContext. Remove FilesetProvider. PiperOrigin-RevId: 208213955
Diffstat (limited to 'src/test')
-rw-r--r--src/test/java/com/google/devtools/build/lib/actions/ExecutableSymlinkActionTest.java1
-rw-r--r--src/test/java/com/google/devtools/build/lib/actions/util/ActionsTestUtil.java6
-rw-r--r--src/test/java/com/google/devtools/build/lib/analysis/actions/FileWriteActionTestCase.java1
-rw-r--r--src/test/java/com/google/devtools/build/lib/analysis/actions/ParamFileWriteActionTest.java3
-rw-r--r--src/test/java/com/google/devtools/build/lib/analysis/actions/SymlinkActionTest.java3
-rw-r--r--src/test/java/com/google/devtools/build/lib/analysis/actions/TemplateExpansionActionTest.java3
-rw-r--r--src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java3
-rw-r--r--src/test/java/com/google/devtools/build/lib/rules/cpp/CreateIncSymlinkActionTest.java3
-rw-r--r--src/test/java/com/google/devtools/build/lib/rules/cpp/LtoBackendActionTest.java3
-rw-r--r--src/test/java/com/google/devtools/build/lib/rules/objc/BazelJ2ObjcLibraryTest.java2
-rw-r--r--src/test/java/com/google/devtools/build/lib/skyframe/FilesetEntryFunctionTest.java184
-rw-r--r--src/test/java/com/google/devtools/build/lib/skyframe/SkyframeAwareActionTest.java6
-rw-r--r--src/test/java/com/google/devtools/build/lib/standalone/StandaloneSpawnStrategyTest.java3
13 files changed, 191 insertions, 30 deletions
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 5f8bf79f1c..9f233b3dd4 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
@@ -66,7 +66,6 @@ public class ExecutableSymlinkActionTest {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
null,
- null,
null);
}
diff --git a/src/test/java/com/google/devtools/build/lib/actions/util/ActionsTestUtil.java b/src/test/java/com/google/devtools/build/lib/actions/util/ActionsTestUtil.java
index 1aa4022b34..80b8e7e403 100644
--- a/src/test/java/com/google/devtools/build/lib/actions/util/ActionsTestUtil.java
+++ b/src/test/java/com/google/devtools/build/lib/actions/util/ActionsTestUtil.java
@@ -147,8 +147,7 @@ public final class ActionsTestUtil {
actionGraph == null
? createDummyArtifactExpander()
: ActionInputHelper.actionGraphArtifactExpander(actionGraph),
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null);
+ /*actionFileSystem=*/ null);
}
public static ActionExecutionContext createContextForInputDiscovery(
@@ -183,8 +182,7 @@ public final class ActionsTestUtil {
ImmutableMap.of(),
ImmutableMap.of(),
createDummyArtifactExpander(),
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null);
+ /*actionFileSystem=*/ null);
}
private static ArtifactExpander createDummyArtifactExpander() {
diff --git a/src/test/java/com/google/devtools/build/lib/analysis/actions/FileWriteActionTestCase.java b/src/test/java/com/google/devtools/build/lib/analysis/actions/FileWriteActionTestCase.java
index fe4b0a2805..12cbfb4ffe 100644
--- a/src/test/java/com/google/devtools/build/lib/analysis/actions/FileWriteActionTestCase.java
+++ b/src/test/java/com/google/devtools/build/lib/analysis/actions/FileWriteActionTestCase.java
@@ -68,7 +68,6 @@ public abstract class FileWriteActionTestCase extends BuildViewTestCase {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
null,
- null,
null);
}
diff --git a/src/test/java/com/google/devtools/build/lib/analysis/actions/ParamFileWriteActionTest.java b/src/test/java/com/google/devtools/build/lib/analysis/actions/ParamFileWriteActionTest.java
index b736576d57..59364a3328 100644
--- a/src/test/java/com/google/devtools/build/lib/analysis/actions/ParamFileWriteActionTest.java
+++ b/src/test/java/com/google/devtools/build/lib/analysis/actions/ParamFileWriteActionTest.java
@@ -203,8 +203,7 @@ public class ParamFileWriteActionTest extends BuildViewTestCase {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
artifactExpander,
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null);
+ /*actionFileSystem=*/ null);
}
private enum KeyAttributes {
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 ae213a4616..c3e25614fd 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
@@ -90,8 +90,7 @@ public class SymlinkActionTest extends BuildViewTestCase {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
null,
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null));
+ /*actionFileSystem=*/ null));
assertThat(actionResult.spawnResults()).isEmpty();
assertThat(output.isSymbolicLink()).isTrue();
assertThat(output.resolveSymbolicLinks()).isEqualTo(input);
diff --git a/src/test/java/com/google/devtools/build/lib/analysis/actions/TemplateExpansionActionTest.java b/src/test/java/com/google/devtools/build/lib/analysis/actions/TemplateExpansionActionTest.java
index b7fc6c755e..48c169af4d 100644
--- a/src/test/java/com/google/devtools/build/lib/analysis/actions/TemplateExpansionActionTest.java
+++ b/src/test/java/com/google/devtools/build/lib/analysis/actions/TemplateExpansionActionTest.java
@@ -192,8 +192,7 @@ public class TemplateExpansionActionTest extends FoundationTestCase {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
null,
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null);
+ /*actionFileSystem=*/ null);
}
private void executeTemplateExpansion(String expected) throws Exception {
diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java
index 9a1816864f..c3bea4f72c 100644
--- a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java
+++ b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java
@@ -2168,8 +2168,7 @@ public abstract class BuildViewTestCase extends FoundationTestCase {
clientEnv,
ImmutableMap.of(),
artifactExpander,
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult*/ null);
+ /*actionFileSystem=*/ null);
}
}
}
diff --git a/src/test/java/com/google/devtools/build/lib/rules/cpp/CreateIncSymlinkActionTest.java b/src/test/java/com/google/devtools/build/lib/rules/cpp/CreateIncSymlinkActionTest.java
index e84c832e47..c447f67450 100644
--- a/src/test/java/com/google/devtools/build/lib/rules/cpp/CreateIncSymlinkActionTest.java
+++ b/src/test/java/com/google/devtools/build/lib/rules/cpp/CreateIncSymlinkActionTest.java
@@ -116,8 +116,7 @@ public class CreateIncSymlinkActionTest extends FoundationTestCase {
private ActionExecutionContext makeDummyContext() {
DummyExecutor executor = new DummyExecutor(fileSystem, rootDirectory);
return new ActionExecutionContext(
- executor, null, null, null, null, null, ImmutableMap.of(), ImmutableMap.of(), null, null,
- null);
+ executor, null, null, null, null, null, ImmutableMap.of(), ImmutableMap.of(), null, null);
}
@Test
diff --git a/src/test/java/com/google/devtools/build/lib/rules/cpp/LtoBackendActionTest.java b/src/test/java/com/google/devtools/build/lib/rules/cpp/LtoBackendActionTest.java
index f8881ee628..25c7e0d444 100644
--- a/src/test/java/com/google/devtools/build/lib/rules/cpp/LtoBackendActionTest.java
+++ b/src/test/java/com/google/devtools/build/lib/rules/cpp/LtoBackendActionTest.java
@@ -90,8 +90,7 @@ public class LtoBackendActionTest extends BuildViewTestCase {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
null,
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null);
+ /*actionFileSystem=*/ null);
}
@Test
diff --git a/src/test/java/com/google/devtools/build/lib/rules/objc/BazelJ2ObjcLibraryTest.java b/src/test/java/com/google/devtools/build/lib/rules/objc/BazelJ2ObjcLibraryTest.java
index c74e14000d..f617673885 100644
--- a/src/test/java/com/google/devtools/build/lib/rules/objc/BazelJ2ObjcLibraryTest.java
+++ b/src/test/java/com/google/devtools/build/lib/rules/objc/BazelJ2ObjcLibraryTest.java
@@ -794,7 +794,6 @@ public class BazelJ2ObjcLibraryTest extends J2ObjcLibraryTest {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
DUMMY_ARTIFACT_EXPANDER,
- null,
null);
ByteArrayOutputStream moduleMapStream = new ByteArrayOutputStream();
ByteArrayOutputStream umbrellaHeaderStream = new ByteArrayOutputStream();
@@ -846,7 +845,6 @@ public class BazelJ2ObjcLibraryTest extends J2ObjcLibraryTest {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
DUMMY_ARTIFACT_EXPANDER,
- null,
null);
ByteArrayOutputStream moduleMapStream = new ByteArrayOutputStream();
diff --git a/src/test/java/com/google/devtools/build/lib/skyframe/FilesetEntryFunctionTest.java b/src/test/java/com/google/devtools/build/lib/skyframe/FilesetEntryFunctionTest.java
index 5e5ff1420c..e972020051 100644
--- a/src/test/java/com/google/devtools/build/lib/skyframe/FilesetEntryFunctionTest.java
+++ b/src/test/java/com/google/devtools/build/lib/skyframe/FilesetEntryFunctionTest.java
@@ -593,6 +593,147 @@ public final class FilesetEntryFunctionTest extends FoundationTestCase {
}
@Test
+ public void testNestedFileFilesetTraversal() throws Exception {
+ Artifact path1 = getSourceArtifact("foo/bar.file");
+ createFile(path1, "blah");
+ Artifact path2 = getSourceArtifact("foo/baz.file");
+ createFile(path2, "what");
+ FilesetTraversalParams inner1 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//foo"),
+ /*fileToTraverse=*/ path1,
+ PathFragment.create("inner-out1"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ FilesetTraversalParams inner2 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//foo"),
+ /*fileToTraverse=*/ path2,
+ PathFragment.create("inner-out2"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ FilesetTraversalParams outer =
+ FilesetTraversalParamsFactory.nestedTraversal(
+ /*ownerLabel=*/ label("//foo:bar"),
+ /*nested=*/ ImmutableList.of(inner1, inner2),
+ PathFragment.create("outer-out"),
+ /*excludes=*/ null);
+ assertSymlinksCreatedInOrder(
+ outer,
+ symlink("outer-out/inner-out1", rootedPath(path1)),
+ symlink("outer-out/inner-out2", rootedPath(path2)));
+ }
+
+ @Test
+ public void testMultiLevelNesting() throws Exception {
+ Artifact path1 = getSourceArtifact("foo/bar.file");
+ createFile(path1, "blah");
+ Artifact path2 = getSourceArtifact("foo/baz.file");
+ createFile(path2, "what");
+ Artifact path3 = getSourceArtifact("foo/hw.file");
+ createFile(path3, "hello");
+ FilesetTraversalParams inner1 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//foo"),
+ /*fileToTraverse=*/ path1,
+ PathFragment.create("inner-out1"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ FilesetTraversalParams inner2 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//foo"),
+ /*fileToTraverse=*/ path2,
+ PathFragment.create("inner-out2"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ FilesetTraversalParams middle1 =
+ FilesetTraversalParamsFactory.nestedTraversal(
+ /*ownerLabel=*/ label("//foo:middle1"),
+ /*nested=*/ ImmutableList.of(inner1, inner2),
+ PathFragment.create("middle-out1"),
+ /*excludes=*/ null);
+
+ FilesetTraversalParams inner3 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//foo:inner3"),
+ /*fileToTraverse=*/ path3,
+ PathFragment.create("inner-out3"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ FilesetTraversalParams middle2 =
+ FilesetTraversalParamsFactory.nestedTraversal(
+ /*ownerLabel=*/ label("//foo:middle2"),
+ /*nested=*/ ImmutableList.of(inner3),
+ PathFragment.create("middle-out2"),
+ /*excludes=*/ null);
+
+ FilesetTraversalParams outer =
+ FilesetTraversalParamsFactory.nestedTraversal(
+ /*ownerLabel=*/ label("//foo:bar"),
+ /*nested=*/ ImmutableList.of(middle1, middle2),
+ PathFragment.create("outer-out"),
+ /*excludes=*/ null);
+ assertSymlinksCreatedInOrder(
+ outer,
+ symlink("outer-out/middle-out1/inner-out1", rootedPath(path1)),
+ symlink("outer-out/middle-out1/inner-out2", rootedPath(path2)),
+ symlink("outer-out/middle-out2/inner-out3", rootedPath(path3)));
+ }
+
+ private void assertNestedRecursiveFilesetTraversal(boolean useInnerDir) throws Exception {
+ Artifact dir = getSourceArtifact("foo/dir");
+ RootedPath fileA = createFile(childOf(dir, "file.a"), "hello");
+ RootedPath fileB = createFile(childOf(dir, "file.b"), "hello");
+ RootedPath fileC = createFile(childOf(dir, "sub/file.c"), "world");
+
+ FilesetTraversalParams inner =
+ FilesetTraversalParamsFactory.recursiveTraversalOfDirectory(
+ /*ownerLabel=*/ label("//foo"),
+ /*directoryToTraverse=*/ dir,
+ PathFragment.create(useInnerDir ? "inner-dir" : ""),
+ /*excludes=*/ null,
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ FilesetTraversalParams outer =
+ FilesetTraversalParamsFactory.nestedTraversal(
+ /*ownerLabel=*/ label("//foo"),
+ /*nested=*/ ImmutableList.of(inner),
+ PathFragment.create("outer-dir"),
+ /*excludes=*/ ImmutableSet.of("file.a", "sub/file.c"));
+
+ if (useInnerDir) {
+ assertSymlinksCreatedInOrder(
+ outer,
+ // no file is excluded, since no files from "inner" are top-level in the outer Fileset
+ symlink("outer-dir/inner-dir/file.a", fileA),
+ symlink("outer-dir/inner-dir/file.b", fileB),
+ symlink("outer-dir/inner-dir/sub/file.c", fileC)); // only top-level files are excluded
+ } else {
+ assertSymlinksCreatedInOrder(
+ outer,
+ // file.a can be excluded because it's top-level (there's no output directory for "inner")
+ symlink("outer-dir/file.b", fileB),
+ symlink("outer-dir/sub/file.c", fileC)); // only top-level files could be excluded
+ }
+ }
+
+ @Test
+ public void testNestedRecursiveFilesetTraversalWithInnerDestDir() throws Exception {
+ assertNestedRecursiveFilesetTraversal(true);
+ }
+
+ @Test
+ public void testNestedRecursiveFilesetTraversalWithoutInnerDestDir() throws Exception {
+ assertNestedRecursiveFilesetTraversal(false);
+ }
+
+ @Test
public void testFileTraversalForDanglingSymlink() throws Exception {
Artifact linkName = getSourceArtifact("foo/dangling.sym");
RootedPath linkTarget = createFile(siblingOf(linkName, "target.file"), "blah");
@@ -930,13 +1071,48 @@ public final class FilesetEntryFunctionTest extends FoundationTestCase {
@Test
public void testFingerprintOfNestedTraversal() throws Exception {
- Artifact nested1 = getSourceArtifact("a/b");
- Artifact nested2 = getSourceArtifact("a/c");
+ FilesetTraversalParams n1 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//blah"),
+ /*fileToTraverse=*/ getSourceArtifact("blah/file.a"),
+ PathFragment.create("output-name"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+
+ FilesetTraversalParams n2 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//blah"),
+ /*fileToTraverse=*/ getSourceArtifact("meow/file.b"),
+ PathFragment.create("output-name"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ ImmutableList<FilesetTraversalParams> nested1 = ImmutableList.of(n1, n2);
+
+ FilesetTraversalParams n3 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//blah"),
+ /*fileToTraverse=*/ getSourceArtifact("brrr/file.c"),
+ PathFragment.create("output-name"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+
+ FilesetTraversalParams n4 =
+ FilesetTraversalParamsFactory.fileTraversal(
+ /*ownerLabel=*/ label("//blah"),
+ /*fileToTraverse=*/ getSourceArtifact("hurr/file.d"),
+ PathFragment.create("output-name"),
+ /*symlinkBehaviorMode=*/ SymlinkBehavior.COPY,
+ /*pkgBoundaryMode=*/ DONT_CROSS,
+ /*strictFilesetOutput=*/ false);
+ ImmutableList<FilesetTraversalParams> nested2 = ImmutableList.of(n3, n4);
new FingerprintTester(
ImmutableMap.<String, Domain>of(
"ownerLabel", notPartOfFingerprint("//foo", "//bar"),
- "nestedArtifact", partOfFingerprint(nested1, nested2),
+ "nested", partOfFingerprint(nested1, nested2),
"destDir", partOfFingerprint("out1", "out2"),
"excludes",
partOfFingerprint(ImmutableSet.<String>of(), ImmutableSet.<String>of("x")))) {
@@ -945,7 +1121,7 @@ public final class FilesetEntryFunctionTest extends FoundationTestCase {
FilesetTraversalParams create(Map<String, ?> kwArgs) throws Exception {
return FilesetTraversalParamsFactory.nestedTraversal(
label((String) kwArgs.get("ownerLabel")),
- (Artifact) kwArgs.get("nestedArtifact"),
+ (ImmutableList<FilesetTraversalParams>) kwArgs.get("nested"),
PathFragment.create((String) kwArgs.get("destDir")),
(Set<String>) kwArgs.get("excludes"));
}
diff --git a/src/test/java/com/google/devtools/build/lib/skyframe/SkyframeAwareActionTest.java b/src/test/java/com/google/devtools/build/lib/skyframe/SkyframeAwareActionTest.java
index 18f117f43a..3060a08d3e 100644
--- a/src/test/java/com/google/devtools/build/lib/skyframe/SkyframeAwareActionTest.java
+++ b/src/test/java/com/google/devtools/build/lib/skyframe/SkyframeAwareActionTest.java
@@ -249,12 +249,11 @@ public class SkyframeAwareActionTest extends TimestampBuilderTestCase {
}
@Override
- public Object establishSkyframeDependencies(Environment env)
+ public void establishSkyframeDependencies(Environment env)
throws ExceptionBase, InterruptedException {
// Establish some Skyframe dependency. A real action would then use this to compute and
// cache data for the execute(...) method.
env.getValue(actionDepKey);
- return null;
}
}
@@ -798,9 +797,8 @@ public class SkyframeAwareActionTest extends TimestampBuilderTestCase {
registerAction(
new SingleOutputSkyframeAwareAction(genFile1, genFile2) {
@Override
- public Object establishSkyframeDependencies(Environment env) throws ExceptionBase {
+ public void establishSkyframeDependencies(Environment env) throws ExceptionBase {
assertThat(env.valuesMissing()).isFalse();
- return null;
}
@Override
diff --git a/src/test/java/com/google/devtools/build/lib/standalone/StandaloneSpawnStrategyTest.java b/src/test/java/com/google/devtools/build/lib/standalone/StandaloneSpawnStrategyTest.java
index ccccc612e1..da31f120d2 100644
--- a/src/test/java/com/google/devtools/build/lib/standalone/StandaloneSpawnStrategyTest.java
+++ b/src/test/java/com/google/devtools/build/lib/standalone/StandaloneSpawnStrategyTest.java
@@ -194,8 +194,7 @@ public class StandaloneSpawnStrategyTest {
ImmutableMap.<String, String>of(),
ImmutableMap.of(),
SIMPLE_ARTIFACT_EXPANDER,
- /*actionFileSystem=*/ null,
- /*skyframeDepsResult=*/ null);
+ /*actionFileSystem=*/ null);
}
@Test