# -*- coding: utf-8; -*-
from __future__ import unicode_literals, absolute_import
from unittest import TestCase
import sqlalchemy as sa
from rattail.autocomplete import customers as mod
from rattail.config import make_config
from rattail.db import Session
class TestCustomerAutocompleter(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.CustomerAutocompleter(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)
enum = self.config.get_enum()
# first create some customers
alice = model.Customer(name='Alice Chalmers')
session.add(alice)
bob = model.Customer(name='Bob Loblaw')
session.add(bob)
charlie = model.Customer(name='Charlie Chaplin')
session.add(charlie)
# searching for nothing yields no results
result = self.autocompleter.autocomplete(session, '')
self.assertEqual(len(result), 0)
# search for 'l' yields all 3 customers
result = self.autocompleter.autocomplete(session, 'l')
self.assertEqual(len(result), 3)
# search for 'cha' yields just 2 customers
result = self.autocompleter.autocomplete(session, 'cha')
self.assertEqual(len(result), 2)
uuids = [info['value'] for info in result]
self.assertIn(alice.uuid, uuids)
self.assertIn(charlie.uuid, uuids)