# -*- coding: utf-8; -*- from __future__ import unicode_literals, absolute_import from unittest import TestCase import sqlalchemy as sa from rattail.autocomplete import vendors as mod from rattail.config import make_config from rattail.db import Session class TestVendorAutocompleter(TestCase): def setUp(self): self.config = self.make_config() self.autocompleter = self.make_autocompleter() def make_config(self): return make_config([], extend=False) def make_autocompleter(self): return mod.VendorAutocompleter(self.config) def test_autocomplete(self): engine = sa.create_engine('sqlite://') model = self.config.get_model() model.Base.metadata.create_all(bind=engine) session = Session(bind=engine) # first create some vendors acme = model.Vendor(name='Acme Wholesale Foods') session.add(acme) bigboy = model.Vendor(name='Big Boy Distributors') session.add(bigboy) # searching for nothing yields no results result = self.autocompleter.autocomplete(session, '') self.assertEqual(len(result), 0) # search for 'd' yields both vendors result = self.autocompleter.autocomplete(session, 'd') self.assertEqual(len(result), 2) # search for 'big' yields just Big Boy result = self.autocompleter.autocomplete(session, 'big') self.assertEqual(len(result), 1) self.assertEqual(result[0]['value'], bigboy.uuid)