# vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: # Copyright 2016-2017 Ryan Roden-Corrent (rcorre) # # 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 . """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): table = sql.SqlTable('Foo', ['a', 'b', 'c']) for row in data: table.insert(row) cat = sqlcategory.SqlCategory('Foo', sort_by=sort_by, sort_order=sort_order) _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.""" table = sql.SqlTable('Foo', ['a', 'b', 'c']) for row in before: table.insert(row) cat = sqlcategory.SqlCategory('Foo') cat.set_pattern(pattern, filter_cols) _validate(cat, after) def test_select(): table = sql.SqlTable('Foo', ['a', 'b', 'c']) table.insert(['foo', 'bar', 'baz']) cat = sqlcategory.SqlCategory('Foo', select='b, c, a') _validate(cat, [('bar', 'baz', 'foo')]) def test_where(): table = sql.SqlTable('Foo', ['a', 'b', 'c']) table.insert(['foo', 'bar', False]) table.insert(['baz', 'biz', True]) cat = sqlcategory.SqlCategory('Foo', where='not c') _validate(cat, [('foo', 'bar', False)]) 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]) cat = sqlcategory.SqlCategory('Foo', select='a, max(b)', group_by='a') _validate(cat, [('bar', 3), ('foo', 2)]) def test_entry(): table = sql.SqlTable('Foo', ['a', 'b', 'c']) assert hasattr(table.Entry, 'a') assert hasattr(table.Entry, 'b') assert hasattr(table.Entry, 'c')