qutebrowser/tests/misc/test_split.py

173 lines
6.2 KiB
Python
Raw Normal View History

2014-11-03 21:27:07 +01:00
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
2015-01-03 15:51:31 +01:00
# Copyright 2014-2015 Florian Bruhin (The Compiler) <mail@qutebrowser.org>
2014-11-03 21:27:07 +01:00
#
# This file is part of qutebrowser.
#
# qutebrowser is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# qutebrowser 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with qutebrowser. If not, see <http://www.gnu.org/licenses/>.
"""Tests for qutebrowser.misc.split."""
2014-11-03 21:27:07 +01:00
2015-04-09 01:06:52 +02:00
import pytest
2014-11-03 21:27:07 +01:00
from qutebrowser.misc import split
2014-11-03 21:27:07 +01:00
2014-11-04 21:08:26 +01:00
# Most tests copied from Python's shlex.
# The original test data set was from shellwords, by Hartmut Goebel.
2014-11-05 07:58:28 +01:00
# Format: input/split|output|without|keep/split|output|with|keep/
2014-11-04 21:06:50 +01:00
test_data = r"""
one two/one|two/one| two/
one "two three" four/one|two three|four/one| "two three"| four/
one 'two three' four/one|two three|four/one| 'two three'| four/
one "two\" three" four/one|two" three|four/one| "two\" three"| four/
one 'two'\'' three' four/one|two' three|four/one| 'two'\'' three'| four/
one "two three/one|two three/one| "two three/
one 'two three/one|two three/one| 'two three/
2014-11-05 07:58:28 +01:00
one\/one\/one\/
one "two\/one|two\/one| "two\/
2014-11-06 08:25:46 +01:00
one /one/one| /
2014-11-09 20:47:27 +01:00
open -t i/open|-t|i/open| -t| i/
foo bar/foo|bar/foo| bar/
foo bar/foo|bar/ foo| bar/
foo bar /foo|bar/ foo| bar| /
foo bar bla fasel/foo|bar|bla|fasel/foo| bar| bla| fasel/
x y z xxxx/x|y|z|xxxx/x| y| z| xxxx/
\x bar/x|bar/\x| bar/
\ x bar/ x|bar/\ x| bar/
2014-11-05 07:58:28 +01:00
\ bar/ bar/\ bar/
foo \x bar/foo|x|bar/foo| \x| bar/
foo \ x bar/foo| x|bar/foo| \ x| bar/
foo \ bar/foo| bar/foo| \ bar/
foo "bar" bla/foo|bar|bla/foo| "bar"| bla/
"foo" "bar" "bla"/foo|bar|bla/"foo"| "bar"| "bla"/
"foo" bar "bla"/foo|bar|bla/"foo"| bar| "bla"/
"foo" bar bla/foo|bar|bla/"foo"| bar| bla/
foo 'bar' bla/foo|bar|bla/foo| 'bar'| bla/
'foo' 'bar' 'bla'/foo|bar|bla/'foo'| 'bar'| 'bla'/
'foo' bar 'bla'/foo|bar|bla/'foo'| bar| 'bla'/
'foo' bar bla/foo|bar|bla/'foo'| bar| bla/
blurb foo"bar"bar"fasel" baz/blurb|foobarbarfasel|baz/blurb| foo"bar"bar"fasel"| baz/
blurb foo'bar'bar'fasel' baz/blurb|foobarbarfasel|baz/blurb| foo'bar'bar'fasel'| baz/
2014-11-05 07:58:28 +01:00
""//""/
''//''/
foo "" bar/foo||bar/foo| ""| bar/
foo '' bar/foo||bar/foo| ''| bar/
foo "" "" "" bar/foo||||bar/foo| ""| ""| ""| bar/
foo '' '' '' bar/foo||||bar/foo| ''| ''| ''| bar/
2014-11-05 07:58:28 +01:00
\"/"/\"/
"\""/"/"\""/
"foo\ bar"/foo\ bar/"foo\ bar"/
"foo\\ bar"/foo\ bar/"foo\\ bar"/
"foo\\ bar\""/foo\ bar"/"foo\\ bar\""/
"foo\\" bar\"/foo\|bar"/"foo\\"| bar\"/
2014-11-05 07:58:28 +01:00
"foo\\ bar\" dfadf"/foo\ bar" dfadf/"foo\\ bar\" dfadf"/
"foo\\\ bar\" dfadf"/foo\\ bar" dfadf/"foo\\\ bar\" dfadf"/
"foo\\\x bar\" dfadf"/foo\\x bar" dfadf/"foo\\\x bar\" dfadf"/
"foo\x bar\" dfadf"/foo\x bar" dfadf/"foo\x bar\" dfadf"/
\'/'/\'/
'foo\ bar'/foo\ bar/'foo\ bar'/
'foo\\ bar'/foo\\ bar/'foo\\ bar'/
"foo\\\x bar\" df'a\ 'df"/foo\\x bar" df'a\ 'df/"foo\\\x bar\" df'a\ 'df"/
\"foo/"foo/\"foo/
\"foo\x/"foox/\"foo\x/
"foo\x"/foo\x/"foo\x"/
"foo\ "/foo\ /"foo\ "/
foo\ xx/foo xx/foo\ xx/
foo\ x\x/foo xx/foo\ x\x/
foo\ x\x\"/foo xx"/foo\ x\x\"/
"foo\ x\x"/foo\ x\x/"foo\ x\x"/
"foo\ x\x\\"/foo\ x\x\/"foo\ x\x\\"/
"foo\ x\x\\""foobar"/foo\ x\x\foobar/"foo\ x\x\\""foobar"/
"foo\ x\x\\"\'"foobar"/foo\ x\x\'foobar/"foo\ x\x\\"\'"foobar"/
"foo\ x\x\\"\'"fo'obar"/foo\ x\x\'fo'obar/"foo\ x\x\\"\'"fo'obar"/
"foo\ x\x\\"\'"fo'obar" 'don'\''t'/foo\ x\x\'fo'obar|don't/"foo\ x\x\\"\'"fo'obar"| 'don'\''t'/
"foo\ x\x\\"\'"fo'obar" 'don'\''t' \\/foo\ x\x\'fo'obar|don't|\/"foo\ x\x\\"\'"fo'obar"| 'don'\''t'| \\/
2014-11-05 07:58:28 +01:00
'foo\ bar'/foo\ bar/'foo\ bar'/
'foo\\ bar'/foo\\ bar/'foo\\ bar'/
foo\ bar/foo bar/foo\ bar/
:-) ;-)/:-)|;-)/:-)| ;-)/
2014-11-05 07:58:28 +01:00
áéíóú/áéíóú/áéíóú/
2014-11-04 21:06:50 +01:00
"""
2015-04-09 01:06:52 +02:00
test_data_lines = test_data.strip().splitlines()
2014-11-09 22:15:44 +01:00
2014-11-03 21:27:07 +01:00
2015-04-09 01:06:52 +02:00
class TestSplit:
2015-04-09 07:35:33 +02:00
2014-11-03 21:27:07 +01:00
"""Test split."""
2015-04-09 01:06:52 +02:00
@pytest.mark.parametrize('cmd, out',
2015-04-09 07:35:33 +02:00
[case.split('/')[:-2]
for case in test_data_lines])
2015-04-09 01:06:52 +02:00
def test_split(self, cmd, out):
2014-11-04 21:06:50 +01:00
"""Test splitting."""
2015-04-09 01:06:52 +02:00
items = split.split(cmd)
assert items == out.split('|')
2014-11-05 07:58:28 +01:00
2015-04-09 01:06:52 +02:00
@pytest.mark.parametrize('cmd',
2015-04-09 07:35:33 +02:00
[case.split('/')[0]
for case in test_data_lines])
2015-04-09 01:06:52 +02:00
def test_split_keep_original(self, cmd):
2014-11-05 07:58:28 +01:00
"""Test if splitting with keep=True yields the original string."""
2015-04-09 01:06:52 +02:00
items = split.split(cmd, keep=True)
assert ''.join(items) == cmd
2014-11-05 07:41:17 +01:00
2015-04-09 01:06:52 +02:00
@pytest.mark.parametrize('cmd, _mid, out',
2015-04-09 07:35:33 +02:00
[case.split('/')[:-1]
for case in test_data_lines])
2015-04-09 01:06:52 +02:00
def test_split_keep(self, cmd, _mid, out):
2014-11-05 07:41:17 +01:00
"""Test splitting with keep=True."""
2015-04-09 01:06:52 +02:00
items = split.split(cmd, keep=True)
assert items == out.split('|')
2015-04-09 01:06:52 +02:00
class TestSimpleSplit:
2015-04-09 07:35:33 +02:00
"""Test simple_split."""
TESTS = {
' foo bar': [' foo', ' bar'],
'foobar': ['foobar'],
' foo bar baz ': [' foo', ' bar', ' baz', ' '],
'f\ti\ts\th': ['f', '\ti', '\ts', '\th'],
'foo\nbar': ['foo', '\nbar'],
}
2015-04-09 01:06:52 +02:00
@pytest.mark.parametrize('test', TESTS)
def test_str_split(self, test):
2015-03-31 20:49:29 +02:00
"""Test if the behavior matches str.split."""
2015-04-09 01:06:52 +02:00
assert split.simple_split(test) == test.rstrip().split()
def test_str_split_maxsplit_1(self):
2015-03-31 20:49:29 +02:00
"""Test if the behavior matches str.split with maxsplit=1."""
2015-04-09 01:06:52 +02:00
s = "foo bar baz"
2015-04-09 07:35:33 +02:00
actual = split.simple_split(s, maxsplit=1)
expected = s.rstrip().split(maxsplit=1)
assert actual == expected
def test_str_split_maxsplit_0(self):
2015-03-31 20:49:29 +02:00
"""Test if the behavior matches str.split with maxsplit=0."""
2015-04-09 01:06:52 +02:00
s = " foo bar baz "
2015-04-09 07:35:33 +02:00
actual = split.simple_split(s, maxsplit=0)
expected = s.rstrip().split(maxsplit=0)
assert actual == expected
2015-04-09 01:06:52 +02:00
@pytest.mark.parametrize('test, expected', TESTS.items())
def test_split_keep(self, test, expected):
"""Test splitting with keep=True."""
2015-04-09 01:06:52 +02:00
assert split.simple_split(test, keep=True) == expected