Mercurial > treepkg
view test/test_cmdexpand.py @ 441:eadcb1bb54e2
Merged revisions 388-399 via svnmerge from
svn+ssh://svn.wald.intevation.org/treepkg/branches/treepkg-status
........
r388 | bricks | 2010-07-28 10:38:50 +0200 (Mi, 28 Jul 2010) | 3 lines
fix if statement
upload hook should be called if it's not empty
........
r389 | bricks | 2010-07-28 13:38:00 +0200 (Mi, 28 Jul 2010) | 2 lines
only rsync specified architectures from cachedir to publishdir
........
r390 | bricks | 2010-07-29 14:07:57 +0200 (Do, 29 Jul 2010) | 2 lines
introduced after_copy_hook and made rsync upload to publishdir optional
........
r391 | bricks | 2010-07-29 15:43:39 +0200 (Do, 29 Jul 2010) | 3 lines
publish package must be default to get original behaviour
be more verbose at publishing
........
r392 | bricks | 2010-07-29 16:50:53 +0200 (Do, 29 Jul 2010) | 2 lines
fix handling of showing only successfull builds together with num packages
........
r393 | bricks | 2010-07-29 16:52:42 +0200 (Do, 29 Jul 2010) | 2 lines
fixed typo
........
r394 | bricks | 2010-07-29 16:59:10 +0200 (Do, 29 Jul 2010) | 2 lines
fixed another typo
........
r395 | bricks | 2010-07-29 18:05:54 +0200 (Do, 29 Jul 2010) | 3 lines
fixed another typo
treepkg is really slow with many revisions
........
r396 | bricks | 2010-08-02 12:41:55 +0200 (Mo, 02 Aug 2010) | 2 lines
fixed typos
........
r397 | bricks | 2010-08-02 17:36:12 +0200 (Mo, 02 Aug 2010) | 3 lines
be more error prone in listing different files
not checking if a dir exists caused several errors if a build wasn't successful
........
r398 | bricks | 2010-08-05 18:21:47 +0200 (Do, 05 Aug 2010) | 2 lines
review changes
........
r399 | bricks | 2010-08-06 13:06:08 +0200 (Fr, 06 Aug 2010) | 4 lines
cleanup modules
fix test_info testcases
added testcases for remove_trailingslashes and expand_filename
........
author | Bjoern Ricks <bricks@intevation.de> |
---|---|
date | Fri, 06 Aug 2010 13:41:54 +0000 |
parents | a2ce575ce82b |
children |
line wrap: on
line source
# Copyright (C) 2007 by Intevation GmbH # Authors: # Bernhard Herzog <bh@intevation.de> # # This program is free software under the GPL (>=v2) # Read the file COPYING coming with the software for details. """Tests for the cmdexpand function""" import unittest from treepkg.cmdexpand import cmdexpand class TestCMDExpand(unittest.TestCase): def test_words(self): """Test cmdexpand with simple whitespace separated words""" self.assertEquals(cmdexpand("abc defg xyz zy"), ['abc', 'defg', 'xyz', 'zy']) def test_single_quoted(self): """Test cmdexpand with some single quoted words""" self.assertEquals(cmdexpand("abc 'defg xyz' zy"), ['abc', 'defg xyz', 'zy']) def test_double_quoted(self): """Test cmdexpand with some double quoted words""" self.assertEquals(cmdexpand('abc "defg xyz" zy'), ['abc', 'defg xyz', 'zy']) def test_word_expansion(self): """Test cmdexpand with simple word expansion""" self.assertEquals(cmdexpand('abc $foo ghi', foo="def"), ['abc', 'def', 'ghi']) self.assertEquals(cmdexpand('abc $foo ghi $bar', foo="def", bar="X"), ['abc', 'def', 'ghi', 'X']) def test_word_expansion_braced_name(self): """Test cmdexpand with word expansion using braced names""" self.assertEquals(cmdexpand('abc ${foo} x${foo}y ghi', foo="def"), ['abc', 'def', 'xdefy', 'ghi']) def test_word_expansion_non_byte_string(self): """Test cmdexpand quoting of dollar signs""" self.assertEquals(cmdexpand('abc $foo $bar ghi', foo=123, bar=u"1 2 3"), ['abc', '123', '1 2 3', 'ghi']) def test_word_expansion_non_identifier(self): """Test cmdexpand word expansion if dollar not followed by identifier""" # $ immediately followed by a non-identifier character self.assertRaises(ValueError, cmdexpand, 'abc $#foo bar', foo="def") def test_word_expansion_inside_words(self): """Test cmdexpand word expansions in parts of words""" self.assertEquals(cmdexpand("$foo x$bar y$baz.", foo="abc", bar="yz", baz="zx"), ["abc", "xyz", "yzx."]) self.assertEquals(cmdexpand("$foo x$bar-$baz.", foo="abc", bar="yz", baz="zx"), ["abc", "xyz-zx."]) def test_case_sensitivity(self): """Test case sensitivity of expansion keys""" self.assertEquals(cmdexpand('abc $foo $Foo $FOO', foo="def", Foo="DEF", FOO="Def"), ['abc', 'def', 'DEF', 'Def']) def test_list_expansion(self): """Test cmdexpand with list expansion""" self.assertEquals(cmdexpand('abc @foo ghi', foo=["d", "e", "f"]), ['abc', 'd', 'e', 'f', 'ghi']) def test_list_expansion_non_string(self): """Test cmdexpand with list expansion""" self.assertEquals(cmdexpand('abc @foo ghi', foo=[1, 1.0, None]), ['abc', '1', '1.0', 'None', 'ghi']) def test_list_expansion_with_iterators(self): """Test cmdexpand with list expansion using an iterator""" self.assertEquals(cmdexpand('abc @foo ghi', foo=(i**2 for i in range(3))), ['abc', '0', '1', '4', 'ghi']) def test_list_expansion_non_identifier(self): """Test cmdexpand with at-sign not followed by identifier""" # @+identifier do not cover entire word self.assertRaises(ValueError, cmdexpand, 'abc @foo, ghi', foo=["d", "e", "f"]) # @ immediately followed by a non-identifier character self.assertRaises(ValueError, cmdexpand, 'abc @. z') def test_list_expansion_inside_word(self): """Test whether cmdexpand raises ValueError for at-signs inside words""" self.assertRaises(ValueError, cmdexpand, 'abc x@foo ghi', foo=["d", "e", "f"]) def test_dollar_quoting(self): """Test cmdexpand quoting of dollar signs""" self.assertEquals(cmdexpand('abc $$foo $foo g$$hi', foo="def"), ['abc', '$foo', 'def', 'g$hi']) def test_atsign_quoting(self): """Test cmdexpand quoting of at-signs""" self.assertEquals(cmdexpand('abc @foo $@foo g$@i', foo=["d", "e", "f"]), ['abc', 'd', 'e', 'f', '@foo', 'g@i']) def test_interaction_with_shlex_quoting(self): """Test cmdexpand's interaction with shlex's quoting""" # Unlike unix-shells the expansion isn't influenced much by # shell quoting as supported by shlex. self.assertEquals(cmdexpand('abc "@foo" \'@foo\' ghi', foo=["d", "e", "f"]), ['abc', 'd', 'e', 'f', 'd', 'e', 'f', 'ghi']) self.assertEquals(cmdexpand('abc "$foo" \'$foo\' ghi', foo="def"), ['abc', 'def', 'def', 'ghi']) self.assertEquals(cmdexpand('abc " $foo" \'a $foo\' ghi', foo="def"), ['abc', ' def', 'a def', 'ghi']) if __name__ == "__main__": unittest.main()