예제 #1
0
def test_datetime():
    from datetime import datetime, date, time
    assert sqlrepr(datetime(2005, 7, 14, 13, 31, 2)) == "'2005-07-14 13:31:02.0'"
    assert sqlrepr(date(2005, 7, 14)) == "'2005-07-14'"
    assert sqlrepr(time(13, 31, 2)) == "'13:31:02.0'"
    # now dates before 1900
    assert sqlrepr(datetime(1428, 7, 14, 13, 31, 2)) == "'1428-07-14 13:31:02.0'"
    assert sqlrepr(date(1428, 7, 14)) == "'1428-07-14'"
예제 #2
0
def test_insert():
    # Single column, no keyword arguments.
    instance = Insert('test', [('test',)])
    assert sqlrepr(instance, 'mysql') == "INSERT INTO test VALUES ('test')"

    # Multiple columns, no keyword arguments.
    instance2 = Insert('test', [('1st', '2nd', '3th', '4th')])
    assert sqlrepr(instance2, 'postgres') == "INSERT INTO test VALUES ('1st', '2nd', '3th', '4th')"

    # Multiple rows, multiple columns, "valueList" keyword argument.
    instance3 = Insert('test', valueList=[('a1', 'b1'), ('a2', 'b2'), ('a3', 'b3')])
    assert sqlrepr(instance3, 'sqlite') == "INSERT INTO test VALUES ('a1', 'b1'), ('a2', 'b2'), ('a3', 'b3')"

    # Multiple columns, "values" keyword argument.
    instance4 = Insert('test', values=('v1', 'v2', 'v3'))
    assert sqlrepr(instance4, 'mysql') == "INSERT INTO test VALUES ('v1', 'v2', 'v3')"

    # Single column, "valueList" keyword argument.
    instance5 = Insert('test', valueList=[('v1',)])
    assert sqlrepr(instance5, 'mysql') == "INSERT INTO test VALUES ('v1')"

    # Multiple rows, Multiple columns, template.
    instance6 = Insert('test', valueList=[('a1', 'b1'), ('a2', 'b2')], template=['col1', 'col2'])
    assert sqlrepr(instance6, 'mysql') == "INSERT INTO test (col1, col2) VALUES ('a1', 'b1'), ('a2', 'b2')"

    # Multiple columns, implicit template (dictionary value).
    instance7 = Insert('test', valueList=[{'col1': 'a1', 'col2': 'b1'}])
    assert sqlrepr(instance7, 'mysql') == "INSERT INTO test (col2, col1) VALUES ('b1', 'a1')"

    # Multiple rows, Multiple columns, implicit template.
    instance8 = Insert('test', valueList=[{'col1': 'a1', 'col2': 'b1'},
                                        {'col1': 'a2', 'col2': 'b2'}])
    assert sqlrepr(instance8, 'mysql') == "INSERT INTO test (col2, col1) VALUES ('b1', 'a1'), ('b2', 'a2')"
예제 #3
0
def test_sets():
    try:
        set
    except NameError:
        pass
    else:
        assert sqlrepr(set([1])) == "(1)"
    if sys.version_info[:3] < (2, 6, 0): # Module sets was deprecated in Python 2.6
        try:
            from sets import Set
        except ImportError:
            pass
        else:
            assert sqlrepr(Set([1])) == "(1)"
예제 #4
0
def test_sets():
    try:
        set
    except NameError:
        pass
    else:
        assert sqlrepr(set([1])) == "(1)"
예제 #5
0
def test_datetime():
    from datetime import datetime, date, time
    if SODateTimeCol.datetimeFormat.find('.%f') > 0:
        assert sqlrepr(datetime(2005, 7, 14, 13, 31, 2)) == \
            "'2005-07-14 13:31:02.000000'"
    else:
        assert sqlrepr(datetime(2005, 7, 14, 13, 31, 2)) == \
            "'2005-07-14 13:31:02'"
    assert sqlrepr(date(2005, 7, 14)) == "'2005-07-14'"
    if SOTimeCol.timeFormat.find('.%f') > 0:
        assert sqlrepr(time(13, 31, 2)) == "'13:31:02.000000'"
    else:
        assert sqlrepr(time(13, 31, 2)) == "'13:31:02'"
    # now dates before 1900
    if SODateTimeCol.datetimeFormat.find('.%f') > 0:
        assert sqlrepr(datetime(1428, 7, 14, 13, 31, 2)) == \
            "'1428-07-14 13:31:02.000000'"
    else:
        assert sqlrepr(datetime(1428, 7, 14, 13, 31, 2)) == \
            "'1428-07-14 13:31:02'"
    assert sqlrepr(date(1428, 7, 14)) == "'1428-07-14'"
예제 #6
0
def test_sqlobjectfield():
    instance = SQLObjectField('test', 'test', 'test', None, None)
    assert sqlrepr(instance) == repr(instance)
예제 #7
0
def test_trueclause():
    instance = SQLTrueClauseClass()
    assert sqlrepr(instance) == repr(instance)
예제 #8
0
def test_bool():
    assert sqlrepr(True, 'postgres') == "'t'"
    assert sqlrepr(False, 'postgres') == "'f'"
    assert sqlrepr(True, 'mysql') == "1"
    assert sqlrepr(False, 'mysql') == "0"
예제 #9
0
def test_none():
    assert sqlrepr(None) == "NULL"
예제 #10
0
def test_string_():
    assert sqlrepr('A String\tAnother', 'postgres') == "E'A String\\tAnother'"
    assert sqlrepr('A String\'Another', 'firebird') == "'A String''Another'"
예제 #11
0
def test_dict():
    assert sqlrepr({"key": "value"}, "sqlite") == "('key')"
예제 #12
0
def test_op():
    instance = SQLOp('and', 'this', 'that')
    assert sqlrepr(instance, 'mysql') == "(('this') AND ('that'))"
예제 #13
0
def test_simple_string():
    assert sqlrepr('A String', 'firebird') == "'A String'"
예제 #14
0
def test_like_quoted():
    assert sqlrepr(_LikeQuoted('test'), 'postgres') == "'test'"
    assert sqlrepr(_LikeQuoted('test'), 'sqlite') == "'test'"
    assert sqlrepr(_LikeQuoted('test%'), 'postgres') == r"E'test\\%'"
    assert sqlrepr(_LikeQuoted('test%'), 'sqlite') == r"'test\%'"
예제 #15
0
def test_timedelta():
    assert sqlrepr(timedelta(seconds=30*60)) == \
        "INTERVAL '0 days 1800 seconds'"
예제 #16
0
def test_dict():
    assert sqlrepr({"key": "value"}, "sqlite") == "('key')"
예제 #17
0
def test_prefix():
    instance = SQLPrefix('test', 'test')
    assert sqlrepr(instance, 'mysql') == "test 'test'"
예제 #18
0
def test_constant():
    instance = SQLConstant('test')
    assert sqlrepr(instance) == repr(instance)
예제 #19
0
def test_update():
    instance = Update('test', {'test': 'test'})
    assert sqlrepr(instance, 'mysql') == "UPDATE test SET test='test'"
예제 #20
0
def test_replace():
    instance = Replace('test', {'test': 'test'})
    assert sqlrepr(instance, 'mysql') == "REPLACE test SET test='test'"
예제 #21
0
def test_string_newline():
    assert sqlrepr('A String\nAnother', 'postgres') == "E'A String\\nAnother'"
    assert sqlrepr('A String\nAnother', 'sqlite') == "'A String\nAnother'"
예제 #22
0
def test_constant():
    instance = SQLConstant('test')
    assert sqlrepr(instance) == repr(instance)
예제 #23
0
def test_string_b():
    assert sqlrepr('A String\bAnother', 'postgres') == "E'A String\\bAnother'"
예제 #24
0
def test_call():
    instance = SQLCall('test', ('test', ))
    assert sqlrepr(instance, 'mysql') == "'test'('test')"
예제 #25
0
def test_string_000():
    assert sqlrepr('A String\000Another',
                   'postgres') == "E'A String\\0Another'"
예제 #26
0
def test_integer():
    assert sqlrepr(10) == "10"
예제 #27
0
def test_string_():
    assert sqlrepr('A String\tAnother', 'postgres') == "E'A String\\tAnother'"
    assert sqlrepr('A String\'Another', 'firebird') == "'A String''Another'"
예제 #28
0
def test_tuple():
    assert sqlrepr(('one', 'two', 'three'), 'postgres') == \
        "('one', 'two', 'three')"
예제 #29
0
def test_simple_unicode():
    assert sqlrepr(u'A String', 'postgres') == "'A String'"
예제 #30
0
def test_integer():
    assert sqlrepr(10) == "10"
예제 #31
0
def test_float():
    assert sqlrepr(10.01) == "10.01"
예제 #32
0
def test_instance():
    instance = TestClass()
    assert sqlrepr(instance) == repr(instance)
예제 #33
0
def test_none():
    assert sqlrepr(None) == "NULL"
예제 #34
0
def test_select():
    instance = Select('test')
    assert sqlrepr(instance, 'mysql') == "SELECT test"
예제 #35
0
def test_list():
    assert sqlrepr(['one', 'two', 'three'],
                   'postgres') == "('one', 'two', 'three')"
예제 #36
0
def test_delete():
    instance = Delete('test', None)
    assert sqlrepr(instance, 'mysql') == "DELETE FROM test"
예제 #37
0
def PostgresBinaryConverter(value, db):
    assert db == 'postgres'
    return sqlrepr(escape_bytea(value), db)
예제 #38
0
def test_trueclause():
    instance = SQLTrueClauseClass()
    assert sqlrepr(instance) == repr(instance)
예제 #39
0
def test_timedelta():
    assert sqlrepr(timedelta(seconds=30 * 60)) == \
        "INTERVAL '0 days 1800 seconds'"
예제 #40
0
def test_call():
    instance = SQLCall('test', ('test',))
    assert sqlrepr(instance, 'mysql') == "'test'('test')"
예제 #41
0
def test_simple_string():
    assert sqlrepr('A String', 'firebird') == "'A String'"
예제 #42
0
def test_prefix():
    instance = SQLPrefix('test', 'test')
    assert sqlrepr(instance, 'mysql') == "test 'test'"
예제 #43
0
def test_string_b():
    assert sqlrepr('A String\bAnother', 'postgres') == "E'A String\\bAnother'"
예제 #44
0
def test_newstyle():
    instance = NewTestClass()
    assert sqlrepr(instance) == repr(instance)
예제 #45
0
def test_op():
    instance = SQLOp('and', 'this', 'that')
    assert sqlrepr(instance, 'mysql') == "(('this') AND ('that'))"
예제 #46
0
def test_like_quoted():
    assert sqlrepr(_LikeQuoted('test'), 'postgres') == "'test'"
    assert sqlrepr(_LikeQuoted('test'), 'sqlite') == "'test'"
    assert sqlrepr(_LikeQuoted('test%'), 'postgres') == r"E'test\\%'"
    assert sqlrepr(_LikeQuoted('test%'), 'sqlite') == r"'test\%'"
예제 #47
0
def test_sqlexpr():
    instance = SQLExpression()
    assert sqlrepr(instance) == repr(instance)
예제 #48
0
def test_string_newline():
    assert sqlrepr('A String\nAnother', 'postgres') == "E'A String\\nAnother'"
    assert sqlrepr('A String\nAnother', 'sqlite') == "'A String\nAnother'"
예제 #49
0
def test_sqlobjectfield():
    instance = SQLObjectField('test', 'test', 'test', None, None)
    assert sqlrepr(instance) == repr(instance)
예제 #50
0
def test_string_000():
    assert sqlrepr('A String\000Another', 'postgres') == \
        "E'A String\\0Another'"
예제 #51
0
def test_select():
    instance = Select('test')
    assert sqlrepr(instance, 'mysql') == "SELECT test"
예제 #52
0
def test_simple_unicode():
    assert sqlrepr(u'A String', 'postgres') == "'A String'"
예제 #53
0
def test_update():
    instance = Update('test', {'test':'test'})
    assert sqlrepr(instance, 'mysql') == "UPDATE test SET test='test'"
예제 #54
0
def test_float():
    assert sqlrepr(10.01) == "10.01"
예제 #55
0
def test_delete():
    instance = Delete('test', None)
    assert sqlrepr(instance, 'mysql') == "DELETE FROM test"
예제 #56
0
def test_list():
    assert sqlrepr(['one', 'two', 'three'], 'postgres') == \
        "('one', 'two', 'three')"
예제 #57
0
def test_replace():
    instance = Replace('test', {'test':'test'})
    assert sqlrepr(instance, 'mysql') == "REPLACE test SET test='test'"
예제 #58
0
 def __sqlrepr__(self, db):
     return "(%s %s (%s))" % (
         self.string, self._get_op(db), sqlrepr(self.expr, db))
예제 #59
0
def test_tuple():
    assert sqlrepr(('one', 'two', 'three'),
                   'postgres') == "('one', 'two', 'three')"