Skip to content
Snippets Groups Projects
Select Git revision
  • fcc99597e635816f37b0ad9f5675834bf1bb63d0
  • main default protected
  • f-fix-multi-import
  • dev protected
  • f-yaml-parser-enums
  • f-fix-paths
  • f-fix-validate-to-dict
  • f-labfolder-converter
  • f-state-machine-script
  • f-xlsx-converter-warnings-errors
  • f-rename
  • f-extra-deps
  • f-more-jsonschema-export
  • f-henrik
  • f-fix-89
  • f-trigger-advanced-user-tools
  • f-real-rename-test
  • f-linkahead-rename
  • f-register-integrationtests
  • f-fix-id
  • f-h5-files
  • v0.14.0
  • v0.13.0
  • v0.12.0
  • v0.11.0
  • v0.10.0-numpy2
  • v0.10.0
  • v0.9.0
  • v0.8.0
  • v0.7.0
  • v0.6.1
  • v0.6.0
  • v0.5.0
  • v0.4.1
  • v0.4.0
  • v0.3.1
  • v0.3.0
37 results

README.md

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    test_utils.py 1.59 KiB
    # coding: utf-8
    #
    # ** header v3.0
    # This file is a part of the LinkAhead Project.
    #
    # Copyright (C) 2018 Research Group Biomedical Physics,
    # Max-Planck-Institute for Dynamics and Self-Organization Göttingen
    #
    # This program is free software: you can redistribute it and/or modify
    # it under the terms of the GNU Affero General Public License as
    # published by the Free Software Foundation, either version 3 of the
    # License, or (at your option) any later version.
    #
    # This program is distributed in the hope that it will be useful,
    # but WITHOUT ANY WARRANTY; without even the implied warranty of
    # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    # GNU Affero General Public License for more details.
    #
    # You should have received a copy of the GNU Affero General Public License
    # along with this program. If not, see <https://www.gnu.org/licenses/>.
    #
    # ** end header
    #
    """Tests for linkahead.common.utils."""
    from __future__ import unicode_literals
    
    from linkahead.common.utils import xml2str
    from linkahead.utils.escape import (escape_dquoted_text, escape_squoted_text)
    from lxml.etree import Element
    
    
    def test_xml2str():
        name = 'Björn'
        element = Element(name)
        serialized = xml2str(element)
        assert serialized == "<Björn/>\n"
    
    
    def test_escape_quoted_text():
        assert escape_squoted_text("bla") == "bla"
        assert escape_squoted_text(r"bl\a") == r"bl\\a"
        assert escape_squoted_text("bl*a") == r"bl\*a"
        assert escape_squoted_text(r"bl*ab\\lab\*labla") == r"bl\*ab\\\\lab\\\*labla"
        assert escape_squoted_text("bl'a") == r"bl\'a"
        assert escape_dquoted_text('bl"a') == r'bl\"a'