File: test_phone_number.py

package info (click to toggle)
wtforms-alchemy 0.19.0-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 492 kB
  • sloc: python: 3,955; makefile: 119; sh: 11
file content (86 lines) | stat: -rw-r--r-- 2,857 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
import sqlalchemy as sa
from pytest import mark
from sqlalchemy import create_engine
from sqlalchemy.orm import declarative_base, sessionmaker
from sqlalchemy.orm.session import close_all_sessions
from sqlalchemy_utils.types import phone_number

from tests import MultiDict
from wtforms_alchemy import ModelForm


class TestCase:
    def setup_method(self, method):
        self.engine = create_engine("sqlite:///:memory:")
        self.Base = declarative_base()

        self.create_models()
        self.Base.metadata.create_all(self.engine)

        Session = sessionmaker(bind=self.engine)
        self.session = Session()

    def teardown_method(self, method):
        close_all_sessions()
        self.Base.metadata.drop_all(self.engine)
        self.engine.dispose()

    def create_models(self):
        class User(self.Base):
            __tablename__ = "user"
            id = sa.Column(sa.Integer, autoincrement=True, primary_key=True)
            name = sa.Column(sa.Unicode(255))
            phone_number = sa.Column(phone_number.PhoneNumberType(country_code="FI"))

        self.User = User


@mark.xfail("phone_number.phonenumbers is None")
class TestPhoneNumbers(TestCase):
    """
    Simple tests to ensure that sqlalchemy_utils.PhoneNumber,
    wtforms_alchemy.PhoneNumberType and sqlalchemy_utils.PhoneNumberField work
    nicely together.
    """

    def setup_method(self, method):
        super().setup_method(method)

        class UserForm(ModelForm):
            class Meta:
                model = self.User

        self.UserForm = UserForm

        super().setup_method(method)
        self.phone_number = phone_number.PhoneNumber("040 1234567", "FI")
        self.user = self.User()
        self.user.name = "Someone"
        self.user.phone_number = self.phone_number
        self.session.add(self.user)
        self.session.commit()

    def test_query_returns_phone_number_object(self):
        queried_user = self.session.query(self.User).first()
        assert queried_user.phone_number == self.phone_number

    def test_phone_number_is_stored_as_string(self):
        result = self.session.execute(
            sa.text("SELECT phone_number FROM user WHERE id=:param"),
            {"param": self.user.id},
        )
        assert result.first()[0] == "+358401234567"

    def test_phone_number_in_form(self):
        form = self.UserForm(
            MultiDict(name="Matti Meikalainen", phone_number="+358401231233")
        )
        form.validate()
        assert len(form.errors) == 0
        assert form.data["phone_number"] == (phone_number.PhoneNumber("+358401231233"))

    def test_empty_phone_number_in_form(self):
        form = self.UserForm(MultiDict(name="Matti Meikalainen", phone_number=""))
        form.validate()
        assert len(form.errors) == 0
        assert form.data["phone_number"] is None