From ac0e8502c33051d7dae34db039ac15435fd7d6bf Mon Sep 17 00:00:00 2001 From: Carsten Bauer Date: Mon, 27 Feb 2023 13:52:33 +0100 Subject: [PATCH] Added test for preference sandboxing of implicit test dependencies (#3389) --- test/sandbox.jl | 14 +++++++ .../Manifest.toml | 39 +++++++++++++++++++ .../Project.toml | 18 +++++++++ .../dev/Foo/Manifest.toml | 10 +++++ .../dev/Foo/Project.toml | 7 ++++ .../dev/Foo/src/Foo.jl | 5 +++ .../dev/FooDep/Manifest.toml | 27 +++++++++++++ .../dev/FooDep/Project.toml | 7 ++++ .../dev/FooDep/src/FooDep.jl | 8 ++++ .../src/Sandbox_PreservePrefsImplicit.jl | 5 +++ .../test/runtests.jl | 2 + 11 files changed, 142 insertions(+) create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/Manifest.toml create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/Project.toml create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Manifest.toml create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Project.toml create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/src/Foo.jl create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Manifest.toml create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Project.toml create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/src/FooDep.jl create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/src/Sandbox_PreservePrefsImplicit.jl create mode 100644 test/test_packages/Sandbox_PreservePrefsImplicit/test/runtests.jl diff --git a/test/sandbox.jl b/test/sandbox.jl index d06ceaea96..903bde0f18 100644 --- a/test/sandbox.jl +++ b/test/sandbox.jl @@ -131,6 +131,20 @@ end end end end +@testset "Preferences sandboxing of implicit test dependencies" begin + # Preferences of FooDep (implicit test dependency via Foo) + # should be copied over into sandbox + temp_pkg_dir() do project_path; mktempdir() do tmp + copy_test_package(tmp, "Sandbox_PreservePrefsImplicit") + Pkg.activate(joinpath(tmp, "Sandbox_PreservePrefsImplicit")) + test_test() do + uuid = UUID("ecddbb86-518e-4a4d-b30b-c11ee99fa784") + @test !Preferences.has_preference(uuid, "does_not_exist") + @test_broken Preferences.load_preference(uuid, "weather") == "sunny" + end + end end +end + @testset "Nested Preferences sandboxing" begin # Preferences should be copied over into sandbox temp_pkg_dir() do project_path; mktempdir() do tmp diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/Manifest.toml b/test/test_packages/Sandbox_PreservePrefsImplicit/Manifest.toml new file mode 100644 index 0000000000..7c5a3a8ae6 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/Manifest.toml @@ -0,0 +1,39 @@ +# This file is machine-generated - editing it directly is not advised + +julia_version = "1.10.0-DEV" +manifest_format = "2.0" +project_hash = "e136fd416d7f0eac7db513d485d3aaa3148ab079" + +[[deps.Dates]] +deps = ["Printf"] +uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" + +[[deps.Foo]] +deps = ["FooDep"] +path = "dev/Foo" +uuid = "128bfcea-dc33-4310-8fcf-6a5a6a7c0677" +version = "0.1.0" + +[[deps.FooDep]] +deps = ["Preferences"] +path = "dev/FooDep" +uuid = "22d90790-ba35-49ef-9cc5-1d4fefcbe869" +version = "0.1.0" + +[[deps.Preferences]] +deps = ["TOML"] +git-tree-sha1 = "47e5f437cc0e7ef2ce8406ce1e7e24d44915f88d" +uuid = "21216c6a-2e73-6563-6e65-726566657250" +version = "1.3.0" + +[[deps.Printf]] +deps = ["Unicode"] +uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" + +[[deps.TOML]] +deps = ["Dates"] +uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" +version = "1.0.3" + +[[deps.Unicode]] +uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/Project.toml b/test/test_packages/Sandbox_PreservePrefsImplicit/Project.toml new file mode 100644 index 0000000000..73132dc5c5 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/Project.toml @@ -0,0 +1,18 @@ +authors = ["Carsten Bauer "] +name = "Sandbox_PreservePrefsImplicit" +uuid = "ecddbb86-518e-4a4d-b30b-c11ee99fa784" +version = "0.1.0" + +[deps] +Foo = "128bfcea-dc33-4310-8fcf-6a5a6a7c0677" + +[extras] +FooDep = "22d90790-ba35-49ef-9cc5-1d4fefcbe869" +Foo = "128bfcea-dc33-4310-8fcf-6a5a6a7c0677" +Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40" + +[preferences] +FooDep.weather = "sunny" + +[targets] +test = ["Test", "Foo"] \ No newline at end of file diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Manifest.toml b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Manifest.toml new file mode 100644 index 0000000000..b2e2be68fe --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Manifest.toml @@ -0,0 +1,10 @@ +# This file is machine-generated - editing it directly is not advised + +julia_version = "1.10.0-DEV" +manifest_format = "2.0" +project_hash = "9562b3808eb1a86b32d5877e169219af8bc5346a" + +[[deps.FooDep]] +path = "../FooDep" +uuid = "22d90790-ba35-49ef-9cc5-1d4fefcbe869" +version = "0.1.0" diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Project.toml b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Project.toml new file mode 100644 index 0000000000..c8bb3b7219 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/Project.toml @@ -0,0 +1,7 @@ +name = "Foo" +uuid = "128bfcea-dc33-4310-8fcf-6a5a6a7c0677" +authors = ["Carsten Bauer "] +version = "0.1.0" + +[deps] +FooDep = "22d90790-ba35-49ef-9cc5-1d4fefcbe869" diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/src/Foo.jl b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/src/Foo.jl new file mode 100644 index 0000000000..6c0416236e --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/Foo/src/Foo.jl @@ -0,0 +1,5 @@ +module Foo + +using FooDep + +end # module Foo diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Manifest.toml b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Manifest.toml new file mode 100644 index 0000000000..6bd9a10a26 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Manifest.toml @@ -0,0 +1,27 @@ +# This file is machine-generated - editing it directly is not advised + +julia_version = "1.10.0-DEV" +manifest_format = "2.0" +project_hash = "5784e7f1610542ec1dd97b517265a6694167840e" + +[[deps.Dates]] +deps = ["Printf"] +uuid = "ade2ca70-3891-5945-98fb-dc099432e06a" + +[[deps.Preferences]] +deps = ["TOML"] +git-tree-sha1 = "47e5f437cc0e7ef2ce8406ce1e7e24d44915f88d" +uuid = "21216c6a-2e73-6563-6e65-726566657250" +version = "1.3.0" + +[[deps.Printf]] +deps = ["Unicode"] +uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7" + +[[deps.TOML]] +deps = ["Dates"] +uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76" +version = "1.0.3" + +[[deps.Unicode]] +uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5" diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Project.toml b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Project.toml new file mode 100644 index 0000000000..3a3d7ce962 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/Project.toml @@ -0,0 +1,7 @@ +name = "FooDep" +uuid = "22d90790-ba35-49ef-9cc5-1d4fefcbe869" +authors = ["Carsten Bauer "] +version = "0.1.0" + +[deps] +Preferences = "21216c6a-2e73-6563-6e65-726566657250" diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/src/FooDep.jl b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/src/FooDep.jl new file mode 100644 index 0000000000..80f67c7d1d --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/dev/FooDep/src/FooDep.jl @@ -0,0 +1,8 @@ +module FooDep + +using Preferences + +set!(key, value) = @set_preferences!(key=>value) +get(key) = @load_preference(key) + +end # module FooDep diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/src/Sandbox_PreservePrefsImplicit.jl b/test/test_packages/Sandbox_PreservePrefsImplicit/src/Sandbox_PreservePrefsImplicit.jl new file mode 100644 index 0000000000..f5803383d0 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/src/Sandbox_PreservePrefsImplicit.jl @@ -0,0 +1,5 @@ +module Sandbox_PreservePrefsImplicit + +using Foo + +end # module Sandbox_PreservePrefsImplicit diff --git a/test/test_packages/Sandbox_PreservePrefsImplicit/test/runtests.jl b/test/test_packages/Sandbox_PreservePrefsImplicit/test/runtests.jl new file mode 100644 index 0000000000..bf6fd826f2 --- /dev/null +++ b/test/test_packages/Sandbox_PreservePrefsImplicit/test/runtests.jl @@ -0,0 +1,2 @@ +# using Foo +# @show Foo.FooDep.get("weather")