2017-03-03 14:31:28 +01:00
|
|
|
# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et:
|
|
|
|
|
|
|
|
# Copyright 2016-2017 Ryan Roden-Corrent (rcorre) <ryan@rcorre.net>
|
|
|
|
#
|
|
|
|
# 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/>.
|
|
|
|
|
|
|
|
"""Test SQL-based completions."""
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
from qutebrowser.misc import sql
|
|
|
|
from qutebrowser.completion.models import sqlcategory
|
|
|
|
|
|
|
|
|
|
|
|
pytestmark = pytest.mark.usefixtures('init_sql')
|
|
|
|
|
|
|
|
|
|
|
|
def _validate(cat, expected):
|
|
|
|
"""Check that a category contains the expected items in the given order.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
cat: The category to inspect.
|
|
|
|
expected: A list of tuples containing the expected items.
|
|
|
|
"""
|
|
|
|
assert cat.rowCount() == len(expected)
|
|
|
|
for row, items in enumerate(expected):
|
|
|
|
for col, item in enumerate(items):
|
|
|
|
assert cat.data(cat.index(row, col)) == item
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('sort_by, sort_order, data, expected', [
|
|
|
|
(None, 'asc',
|
|
|
|
[('B', 'C', 'D'), ('A', 'F', 'C'), ('C', 'A', 'G')],
|
|
|
|
[('B', 'C', 'D'), ('A', 'F', 'C'), ('C', 'A', 'G')]),
|
|
|
|
|
|
|
|
('a', 'asc',
|
|
|
|
[('B', 'C', 'D'), ('A', 'F', 'C'), ('C', 'A', 'G')],
|
|
|
|
[('A', 'F', 'C'), ('B', 'C', 'D'), ('C', 'A', 'G')]),
|
|
|
|
|
|
|
|
('a', 'desc',
|
|
|
|
[('B', 'C', 'D'), ('A', 'F', 'C'), ('C', 'A', 'G')],
|
|
|
|
[('C', 'A', 'G'), ('B', 'C', 'D'), ('A', 'F', 'C')]),
|
|
|
|
|
|
|
|
('b', 'asc',
|
|
|
|
[('B', 'C', 'D'), ('A', 'F', 'C'), ('C', 'A', 'G')],
|
|
|
|
[('C', 'A', 'G'), ('B', 'C', 'D'), ('A', 'F', 'C')]),
|
|
|
|
|
|
|
|
('b', 'desc',
|
|
|
|
[('B', 'C', 'D'), ('A', 'F', 'C'), ('C', 'A', 'G')],
|
|
|
|
[('A', 'F', 'C'), ('B', 'C', 'D'), ('C', 'A', 'G')]),
|
|
|
|
|
|
|
|
('c', 'asc',
|
|
|
|
[('B', 'C', 2), ('A', 'F', 0), ('C', 'A', 1)],
|
|
|
|
[('A', 'F', 0), ('C', 'A', 1), ('B', 'C', 2)]),
|
|
|
|
|
|
|
|
('c', 'desc',
|
|
|
|
[('B', 'C', 2), ('A', 'F', 0), ('C', 'A', 1)],
|
|
|
|
[('B', 'C', 2), ('C', 'A', 1), ('A', 'F', 0)]),
|
|
|
|
])
|
|
|
|
def test_sorting(sort_by, sort_order, data, expected):
|
2017-04-04 14:27:42 +02:00
|
|
|
table = sql.SqlTable('Foo', ['a', 'b', 'c'])
|
2017-03-03 14:31:28 +01:00
|
|
|
for row in data:
|
|
|
|
table.insert(row)
|
2017-05-23 15:01:20 +02:00
|
|
|
cat = sqlcategory.SqlCategory('Foo', filter_fields=['a'], sort_by=sort_by,
|
2017-03-03 14:31:28 +01:00
|
|
|
sort_order=sort_order)
|
2017-05-25 18:59:05 +02:00
|
|
|
cat.set_pattern('')
|
2017-03-03 14:31:28 +01:00
|
|
|
_validate(cat, expected)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('pattern, filter_cols, before, after', [
|
|
|
|
('foo', [0],
|
|
|
|
[('foo', '', ''), ('bar', '', ''), ('aafobbb', '', '')],
|
|
|
|
[('foo',)]),
|
|
|
|
|
|
|
|
('foo', [0],
|
|
|
|
[('baz', 'bar', 'foo'), ('foo', '', ''), ('bar', 'foo', '')],
|
|
|
|
[('foo', '', '')]),
|
|
|
|
|
|
|
|
('foo', [0],
|
|
|
|
[('fooa', '', ''), ('foob', '', ''), ('fooc', '', '')],
|
|
|
|
[('fooa', '', ''), ('foob', '', ''), ('fooc', '', '')]),
|
|
|
|
|
|
|
|
('foo', [1],
|
|
|
|
[('foo', 'bar', ''), ('bar', 'foo', '')],
|
|
|
|
[('bar', 'foo', '')]),
|
|
|
|
|
|
|
|
('foo', [0, 1],
|
|
|
|
[('foo', 'bar', ''), ('bar', 'foo', ''), ('biz', 'baz', 'foo')],
|
|
|
|
[('foo', 'bar', ''), ('bar', 'foo', '')]),
|
|
|
|
|
|
|
|
('foo', [0, 1, 2],
|
|
|
|
[('foo', '', ''), ('bar', '', ''), ('baz', 'bar', 'foo')],
|
|
|
|
[('foo', '', ''), ('baz', 'bar', 'foo')]),
|
|
|
|
|
|
|
|
('foo bar', [0],
|
|
|
|
[('foo', '', ''), ('bar foo', '', ''), ('xfooyybarz', '', '')],
|
|
|
|
[('xfooyybarz', '', '')]),
|
|
|
|
|
|
|
|
('foo%bar', [0],
|
|
|
|
[('foo%bar', '', ''), ('foo bar', '', ''), ('foobar', '', '')],
|
|
|
|
[('foo%bar', '', '')]),
|
|
|
|
|
|
|
|
('_', [0],
|
|
|
|
[('a_b', '', ''), ('__a', '', ''), ('abc', '', '')],
|
|
|
|
[('a_b', '', ''), ('__a', '', '')]),
|
|
|
|
|
|
|
|
('%', [0, 1],
|
|
|
|
[('\\foo', '\\bar', '')],
|
|
|
|
[]),
|
|
|
|
|
|
|
|
("can't", [0],
|
|
|
|
[("can't touch this", '', ''), ('a', '', '')],
|
|
|
|
[("can't touch this", '', '')]),
|
|
|
|
])
|
|
|
|
def test_set_pattern(pattern, filter_cols, before, after):
|
|
|
|
"""Validate the filtering and sorting results of set_pattern."""
|
2017-04-04 14:27:42 +02:00
|
|
|
table = sql.SqlTable('Foo', ['a', 'b', 'c'])
|
2017-03-03 14:31:28 +01:00
|
|
|
for row in before:
|
|
|
|
table.insert(row)
|
2017-05-23 15:01:20 +02:00
|
|
|
filter_fields = [['a', 'b', 'c'][i] for i in filter_cols]
|
|
|
|
cat = sqlcategory.SqlCategory('Foo', filter_fields=filter_fields)
|
2017-03-03 14:31:28 +01:00
|
|
|
cat.set_pattern(pattern, filter_cols)
|
|
|
|
_validate(cat, after)
|
|
|
|
|
|
|
|
|
|
|
|
def test_select():
|
2017-04-04 14:27:42 +02:00
|
|
|
table = sql.SqlTable('Foo', ['a', 'b', 'c'])
|
2017-03-03 14:31:28 +01:00
|
|
|
table.insert(['foo', 'bar', 'baz'])
|
2017-05-23 15:01:20 +02:00
|
|
|
cat = sqlcategory.SqlCategory('Foo', filter_fields=['a'], select='b, c, a')
|
2017-05-25 18:59:05 +02:00
|
|
|
cat.set_pattern('')
|
2017-03-03 14:31:28 +01:00
|
|
|
_validate(cat, [('bar', 'baz', 'foo')])
|
|
|
|
|
|
|
|
|
|
|
|
def test_where():
|
2017-04-04 14:27:42 +02:00
|
|
|
table = sql.SqlTable('Foo', ['a', 'b', 'c'])
|
2017-03-03 14:31:28 +01:00
|
|
|
table.insert(['foo', 'bar', False])
|
|
|
|
table.insert(['baz', 'biz', True])
|
2017-05-23 15:01:20 +02:00
|
|
|
cat = sqlcategory.SqlCategory('Foo', filter_fields=['a'], where='not c')
|
2017-05-25 18:59:05 +02:00
|
|
|
cat.set_pattern('')
|
2017-03-03 14:31:28 +01:00
|
|
|
_validate(cat, [('foo', 'bar', False)])
|
|
|
|
|
|
|
|
|
2017-04-18 13:48:11 +02:00
|
|
|
def test_group():
|
|
|
|
table = sql.SqlTable('Foo', ['a', 'b'])
|
|
|
|
table.insert(['foo', 1])
|
|
|
|
table.insert(['bar', 3])
|
|
|
|
table.insert(['foo', 2])
|
|
|
|
table.insert(['bar', 0])
|
2017-05-23 15:01:20 +02:00
|
|
|
cat = sqlcategory.SqlCategory('Foo', filter_fields=['a'],
|
|
|
|
select='a, max(b)', group_by='a')
|
2017-05-25 18:59:05 +02:00
|
|
|
cat.set_pattern('')
|
2017-04-18 13:48:11 +02:00
|
|
|
_validate(cat, [('bar', 3), ('foo', 2)])
|
|
|
|
|
|
|
|
|
2017-03-03 14:31:28 +01:00
|
|
|
def test_entry():
|
2017-04-04 14:27:42 +02:00
|
|
|
table = sql.SqlTable('Foo', ['a', 'b', 'c'])
|
2017-03-03 14:31:28 +01:00
|
|
|
assert hasattr(table.Entry, 'a')
|
|
|
|
assert hasattr(table.Entry, 'b')
|
|
|
|
assert hasattr(table.Entry, 'c')
|