| # |
| # 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. |
| # |
| |
| # Pylint doesn't play well with fixtures and dependency injection from pytest |
| # pylint: disable=redefined-outer-name |
| |
| import os |
| import pytest |
| |
| from buildstream._testing import cli_integration as cli # pylint: disable=unused-import |
| from buildstream._testing._utils.site import HAVE_SANDBOX |
| |
| |
| pytestmark = pytest.mark.integration |
| |
| |
| DATA_DIR = os.path.join(os.path.dirname(os.path.realpath(__file__)), "project") |
| |
| |
| @pytest.mark.datafiles(DATA_DIR) |
| @pytest.mark.skipif(not HAVE_SANDBOX, reason="Only available with a functioning sandbox") |
| def test_absolute_symlinks(cli, datafiles): |
| project = str(datafiles) |
| checkout = os.path.join(cli.directory, "checkout") |
| element_name = "symlinks/dangling-symlink.bst" |
| |
| result = cli.run(project=project, args=["build", element_name]) |
| assert result.exit_code == 0 |
| |
| result = cli.run(project=project, args=["artifact", "checkout", element_name, "--directory", checkout]) |
| assert result.exit_code == 0 |
| |
| symlink = os.path.join(checkout, "opt", "orgname") |
| assert os.path.islink(symlink) |
| |
| # The symlink is created to point to /usr/orgs/orgname and BuildStream |
| # should not mangle symlinks. |
| assert os.readlink(symlink) == "/usr/orgs/orgname" |
| |
| |
| @pytest.mark.datafiles(DATA_DIR) |
| @pytest.mark.skipif(not HAVE_SANDBOX, reason="Only available with a functioning sandbox") |
| def test_disallow_overlaps_inside_symlink_with_dangling_target(cli, datafiles): |
| project = str(datafiles) |
| checkout = os.path.join(cli.directory, "checkout") |
| element_name = "symlinks/dangling-symlink-overlap.bst" |
| |
| result = cli.run(project=project, args=["build", element_name]) |
| assert result.exit_code == 0 |
| |
| result = cli.run(project=project, args=["artifact", "checkout", element_name, "--directory", checkout]) |
| assert result.exit_code == -1 |
| assert "Destination is a symlink, not a directory: /opt/orgname" in result.stderr |
| |
| |
| @pytest.mark.datafiles(DATA_DIR) |
| @pytest.mark.skipif(not HAVE_SANDBOX, reason="Only available with a functioning sandbox") |
| def test_detect_symlink_overlaps_pointing_outside_sandbox(cli, datafiles): |
| project = str(datafiles) |
| checkout = os.path.join(cli.directory, "checkout") |
| element_name = "symlinks/symlink-to-outside-sandbox-overlap.bst" |
| |
| # Building the two elements should succeed... |
| result = cli.run(project=project, args=["build", element_name]) |
| assert result.exit_code == 0 |
| |
| # ...but when we compose them together, the overlaps create paths that |
| # point outside the sandbox which BuildStream needs to detect before it |
| # tries to actually write there. |
| result = cli.run(project=project, args=["artifact", "checkout", element_name, "--directory", checkout]) |
| assert result.exit_code == -1 |
| assert "Destination is a symlink, not a directory: /opt/escape-hatch" in result.stderr |
| |
| |
| @pytest.mark.datafiles(DATA_DIR) |
| @pytest.mark.skipif(not HAVE_SANDBOX, reason="Only available with a functioning sandbox") |
| def test_symlink_in_sandbox_path(cli, datafiles): |
| project = str(datafiles) |
| element_name = "symlinks/link-on-path-use.bst" |
| base_element_name = "symlinks/link-on-path.bst" |
| # This test is inspired by how freedesktop-SDK has /bin -> /usr/bin |
| |
| # Create a element that has sh in altbin and a link from bin to altbin |
| result1 = cli.run(project=project, args=["build", base_element_name]) |
| result1.assert_success() |
| # Build a element that uses the element that has sh in altbin. |
| result2 = cli.run(project=project, args=["build", element_name]) |
| result2.assert_success() |
| # When this element is built it demonstrates that the virtual sandbox |
| # can detect sh across links and that the sandbox can find sh accross |
| # the link from its PATH. |