# -*- coding: utf-8; -*- import os import shutil import tempfile from unittest import TestCase from unittest.mock import patch, MagicMock import sqlalchemy as sa from sqlalchemy import orm from sqlalchemy.engine import Engine from sqlalchemy.pool import NullPool from wuttjamaican import app, db from wuttjamaican.conf import WuttaConfig class TestAppHandler(TestCase): def setUp(self): self.config = WuttaConfig(appname='wuttatest') self.app = app.AppHandler(self.config) def test_init(self): self.assertIs(self.app.config, self.config) self.assertEqual(self.app.handlers, {}) self.assertEqual(self.app.appname, 'wuttatest') def test_make_appdir(self): # appdir is created, and 3 subfolders added by default tempdir = tempfile.mkdtemp() appdir = os.path.join(tempdir, 'app') self.assertFalse(os.path.exists(appdir)) self.app.make_appdir(appdir) self.assertTrue(os.path.exists(appdir)) self.assertEqual(len(os.listdir(appdir)), 3) shutil.rmtree(tempdir) # subfolders still added if appdir already exists tempdir = tempfile.mkdtemp() self.assertTrue(os.path.exists(tempdir)) self.assertEqual(len(os.listdir(tempdir)), 0) self.app.make_appdir(tempdir) self.assertEqual(len(os.listdir(tempdir)), 3) shutil.rmtree(tempdir) def test_make_engine_from_config_basic(self): engine = self.app.make_engine_from_config({ 'sqlalchemy.url': 'sqlite://', }) self.assertIsInstance(engine, Engine) def test_make_engine_from_config_poolclass(self): engine = self.app.make_engine_from_config({ 'sqlalchemy.url': 'sqlite://', }) self.assertNotIsInstance(engine.pool, NullPool) engine = self.app.make_engine_from_config({ 'sqlalchemy.url': 'sqlite://', 'sqlalchemy.poolclass': 'sqlalchemy.pool:NullPool', }) self.assertIsInstance(engine.pool, NullPool) def test_make_engine_from_config_pool_pre_ping(self): engine = self.app.make_engine_from_config({ 'sqlalchemy.url': 'sqlite://', }) self.assertFalse(engine.pool._pre_ping) engine = self.app.make_engine_from_config({ 'sqlalchemy.url': 'sqlite://', 'sqlalchemy.pool_pre_ping': 'true', }) self.assertTrue(engine.pool._pre_ping) def test_make_session(self): session = self.app.make_session() self.assertIsInstance(session, db.Session.class_) def test_short_session(self): short_session = MagicMock() mockdb = MagicMock(short_session=short_session) with patch.dict('sys.modules', **{'wuttjamaican.db': mockdb}): with self.app.short_session(foo='bar') as s: short_session.assert_called_once_with( foo='bar', factory=self.app.make_session) def test_get_setting(self): Session = orm.sessionmaker() engine = sa.create_engine('sqlite://') session = Session(bind=engine) session.execute(sa.text(""" create table setting ( name varchar(255) primary key, value text ); """)) session.commit() value = self.app.get_setting(session, 'foo') self.assertIsNone(value) session.execute(sa.text("insert into setting values ('foo', 'bar');")) value = self.app.get_setting(session, 'foo') self.assertEqual(value, 'bar')