summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin.mock/packages/view-resolve-conflict-top/package.py
diff options
context:
space:
mode:
Diffstat (limited to 'var/spack/repos/builtin.mock/packages/view-resolve-conflict-top/package.py')
-rw-r--r--var/spack/repos/builtin.mock/packages/view-resolve-conflict-top/package.py26
1 files changed, 26 insertions, 0 deletions
diff --git a/var/spack/repos/builtin.mock/packages/view-resolve-conflict-top/package.py b/var/spack/repos/builtin.mock/packages/view-resolve-conflict-top/package.py
new file mode 100644
index 0000000000..22ddde633b
--- /dev/null
+++ b/var/spack/repos/builtin.mock/packages/view-resolve-conflict-top/package.py
@@ -0,0 +1,26 @@
+# Copyright 2013-2024 Lawrence Livermore National Security, LLC and other
+# Spack Project Developers. See the top-level COPYRIGHT file for details.
+#
+# SPDX-License-Identifier: (Apache-2.0 OR MIT)
+
+import os
+
+from spack.package import *
+
+
+class ViewResolveConflictTop(Package):
+ """Package for testing edge cases for views, such as spec ordering and clashing files referring
+ to the same file on disk. See test_env_view_resolves_identical_file_conflicts."""
+
+ has_code = False
+
+ version("0.1.0")
+ depends_on("view-file")
+ depends_on("view-resolve-conflict-middle")
+
+ def install(self, spec, prefix):
+ middle = spec["view-resolve-conflict-middle"].prefix
+ bottom = spec["view-file"].prefix
+ os.mkdir(os.path.join(prefix, "bin"))
+ os.symlink(os.path.join(bottom, "bin", "x"), os.path.join(prefix, "bin", "x"))
+ os.symlink(os.path.join(middle, "bin", "y"), os.path.join(prefix, "bin", "y"))