[pkg-php-pear] Bug#700791: php-xml-serializer: unhandled symlink to directory conversion: /usr/share/php/tests/XML_Serializer/tests

Andreas Beckmann anbe at debian.org
Sun Feb 17 14:30:25 UTC 2013


Package: php-xml-serializer
Version: 0.20.2-2
Severity: serious
User: debian-qa at lists.debian.org
Usertags: piuparts

Hi,

an upgrade test with piuparts revealed that your package installs files
over existing symlinks and possibly overwrites files owned by other
packages. This usually means an old version of the package shipped a
symlink but that was later replaced by a real (and non-empty)
directory. This kind of overwriting another package's files cannot be
detected by dpkg.

This was observed on the following upgrade paths:

  squeeze -> wheezy

For /usr/share/doc/PACKAGE this may not be problematic as long as both
packages are installed, ship byte-for-byte identical files and are
upgraded in lockstep. But once one of the involved packages gets
removed, the other one will lose its documentation files, too,
including the copyright file, which is a violation of Policy 12.5:
http://www.debian.org/doc/debian-policy/ch-docs.html#s-copyrightfile

For other overwritten locations anything interesting may happen.

Note that dpkg intentionally does not replace directories with symlinks
and vice versa, you need the maintainer scripts to do this.
See in particular the end of point 4 in
http://www.debian.org/doc/debian-policy/ch-maintainerscripts.html#s-unpackphase

For switching from a symlink to a directory, the *preinst* script
should do something like this:

        DOCDIR=/usr/share/doc/@@PACKAGE@@

        if [ -L $DOCDIR ]; then
                rm $DOCDIR
        fi


>From the attached log (usually somewhere in the middle...):

0m48.0s INFO: dirname part contains a symlink:
  /usr/share/php/tests/XML_Serializer/tests/AllTests.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/AllTests.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Arrays_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Arrays_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Objects_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Objects_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_AttributesContent_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_AttributesContent_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_CDataSections_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_CDataSections_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_ClassName_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_ClassName_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_Comment_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_Comment_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_DefaultTag_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_DefaultTag_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_DocType_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_DocType_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_EncodeFunc_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_EncodeFunc_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_IgnoreNull_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_IgnoreNull_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_Indent_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_Indent_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_Linebreaks_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_Linebreaks_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_Mode_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_Mode_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_Namespace_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_Namespace_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_ReturnResult_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_ReturnResult_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_RootAttributes_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_RootAttributes_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_RootName_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_RootName_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_TagMap_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_TagMap_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_TypeHints_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_TypeHints_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Option_XmlDeclaration_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Option_XmlDeclaration_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Serializer_Scalars_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Serializer_Scalars_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Unserializer_Arrays_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Unserializer_Arrays_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Unserializer_Objects_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Unserializer_Objects_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Unserializer_Option_Encodings_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Unserializer_Option_Encodings_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Unserializer_Option_GuessTypes_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Unserializer_Option_GuessTypes_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Unserializer_Option_Whitespace_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Unserializer_Option_Whitespace_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/Unserializer_Scalars_TestCase.php (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/Unserializer_Scalars_TestCase.php (?)
  /usr/share/php/tests/XML_Serializer/tests/bug-12139.phpt (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/bug-12139.phpt (?)
  /usr/share/php/tests/XML_Serializer/tests/bug-13896.phpt (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/bug-13896.phpt (?)
  /usr/share/php/tests/XML_Serializer/tests/bug-15602.phpt (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/bug-15602.phpt (?)
  /usr/share/php/tests/XML_Serializer/tests/bug-9799.phpt (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/bug-9799.phpt (?)
  /usr/share/php/tests/XML_Serializer/tests/req-13564.phpt (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/req-13564.phpt (?)
  /usr/share/php/tests/XML_Serializer/tests/show_ScalarAsAttributes_usage.phpt (php-xml-serializer) != /usr/share/doc/php-xml-serializer/tests/show_ScalarAsAttributes_usage.phpt (?)

I have no idea how to properly cleanup such a "broken path setup" during upgrades.


cheers,

Andreas
-------------- next part --------------
A non-text attachment was scrubbed...
Name: php-xml-serializer_0.20.2-2.log.gz
Type: application/x-gzip
Size: 29754 bytes
Desc: not available
URL: <http://lists.alioth.debian.org/pipermail/pkg-php-pear/attachments/20130217/fd0687ec/attachment-0001.bin>


More information about the pkg-php-pear mailing list