[pacman-dev] [PATCH] Detect potental confict when symlink to directory is changing to directory
Andrew Gregory
andrew.gregory.8 at gmail.com
Fri Dec 4 19:13:18 UTC 2015
s/potental/potential/ s/confict/conflict/
On 12/04/15 at 07:41am, Allan McRae wrote:
> When a symlink to a directory is changing to a directory and takes a file with
> it, pacman does not result the path of the file on the filesystem when checking
The paths in question actually just need to be skipped altogether, not
resolved.
> for conflicts.
>
> Reported by Neofytos and Luca from Chakra.
>
> Signed-off-by: Allan McRae <allan at archlinux.org>
> ---
>
> This only works based on pacmans return failure. Why is the usr/include/bar being
> detected as a directory and not a symlink?
>
>
> test/pacman/tests/TESTS | 1 +
> test/pacman/tests/symlink021.py | 27 +++++++++++++++++++++++++++
> 2 files changed, 28 insertions(+)
> create mode 100644 test/pacman/tests/symlink021.py
>
> diff --git a/test/pacman/tests/TESTS b/test/pacman/tests/TESTS
> index e330896..bee7c8e 100644
> --- a/test/pacman/tests/TESTS
> +++ b/test/pacman/tests/TESTS
> @@ -150,6 +150,7 @@ TESTS += test/pacman/tests/symlink010.py
> TESTS += test/pacman/tests/symlink011.py
> TESTS += test/pacman/tests/symlink012.py
> TESTS += test/pacman/tests/symlink020.py
> +TESTS += test/pacman/tests/symlink021.py
> TESTS += test/pacman/tests/sync-install-assumeinstalled.py
> TESTS += test/pacman/tests/sync-nodepversion01.py
> TESTS += test/pacman/tests/sync-nodepversion02.py
> diff --git a/test/pacman/tests/symlink021.py b/test/pacman/tests/symlink021.py
Our more recent tests use more descriptive names.
> new file mode 100644
> index 0000000..800094d
> --- /dev/null
> +++ b/test/pacman/tests/symlink021.py
> @@ -0,0 +1,27 @@
> +self.description = "symlink -> dir replacment with file move"
> +
> +lp1 = pmpkg("pkg1")
> +lp1.files = ["usr/include/foo/",
> + "usr/include/bar -> foo",
> + "usr/include/foo/header.h"]
> +self.addpkg2db("local", lp1)
> +
> +sp1 = pmpkg("pkg1", "1.0-2")
> +sp1.files = ["usr/include/foo/"]
> +self.addpkg2db("sync", sp1)
> +
> +sp2 = pmpkg("pkg2", "1.0-2")
> +sp2.files = ["usr/include/bar/",
> + "usr/include/bar/header.h"]
> +self.addpkg2db("sync", sp2)
> +
> +
> +self.args = "-S %s %s" % (sp1.name, sp2.name)
> +
> +self.addrule("PACMAN_RETCODE=0")
> +self.addrule("FILE_TYPE=usr/include/foo|dir")
> +self.addrule("FILE_TYPE=usr/include/bar|dir")
> +self.addrule("FILE_EXIST=usr/include/foo/header.h")
usr/include/foo/header.h is not in the updated package's file list.
> +self.addrule("FILE_EXIST=usr/include/bar/header.h")
> +
> +self.expectfailure = True
> --
> 2.6.3
More information about the pacman-dev
mailing list