示例#1
0
 def test_where_clause(self):
     qb = QueryBuilder('company')
     qb.where("a")
     self.assertEqual(qb.incomplete_filter_flag, True)
     self.assertEqual(len(qb.filters), 1)
     self.assertEqual(qb.filters[0], 'a')
示例#2
0
 def test_equal_clause_raise_error_without_where(self):
     qb = QueryBuilder('company')
     self.assertRaisesRegexp(InvalidQueryError,
                             r'preceeded by where',
                             qb.equals, 'a')
示例#3
0
 def test_select_columns_tuple(self):
     qb = QueryBuilder('company')
     columns = ('a', 'b')
     columns_str = ", ".join(columns)
     qb.select(columns)
     self.assertEqual(qb.columns, columns_str)
示例#4
0
 def test_get_columns_all(self):
     qb = QueryBuilder('company')
     self.assertEqual(qb.get_columns(), '*')
示例#5
0
 def test_like_clause(self):
     qb = QueryBuilder('company')
     qb.where("a").like("5")
     self._test_clause(qb, "a", "Like", "'5'")
示例#6
0
 def test_select_chainable(self):
     qb = QueryBuilder('company')
     ret = qb.select("a, b")
     self.assertEqual(qb, ret)
 def test_get_columns_all(self):
     qb = QueryBuilder("company")
     self.assertEqual(qb.get_columns(), "*")
示例#8
0
 def test_contains_clause_raises_exception_str_value(self):
     qb = QueryBuilder('company')
     values = "fgf"
     qb = qb.where('a')
     self.assertRaisesRegexp(InvalidQueryError, "list/tuple of values",
                             qb.contains, values)
 def test_select_columns_tuple(self):
     qb = QueryBuilder("company")
     columns = ("a", "b")
     columns_str = ", ".join(columns)
     qb.select(columns)
     self.assertEqual(qb.columns, columns_str)
示例#10
0
 def test_select_columns_str(self):
     qb = QueryBuilder("company")
     columns = "a,b"
     qb.select(columns)
     self.assertEqual(qb.columns, columns)
示例#11
0
 def _test_clause_chainable(self, clause, param, where=True):
     qb = QueryBuilder("company")
     if where:
         qb.where("a")
     ret = getattr(qb, clause)(param)
     self.assertEqual(qb, ret)
示例#12
0
 def test_like_clause_raise_error_on_non_str(self):
     qb = QueryBuilder("company")
     qb.where("a")
     self.assertRaisesRegexp(InvalidQueryError, r"value be of type string", qb.like, True)
示例#13
0
 def test_select_chainable(self):
     qb = QueryBuilder("company")
     ret = qb.select("a, b")
     self.assertEqual(qb, ret)
示例#14
0
 def test_equal_clause(self):
     qb = QueryBuilder('company')
     qb.where("a").equals("b")
     self._test_clause(qb, "a", '=', "'b'")
示例#15
0
 def test_get_columns_specified(self):
     qb = QueryBuilder("company")
     columns = "a, b"
     qb.select(columns)
     self.assertEqual(qb.get_columns(), columns)
示例#16
0
 def test_like_clause(self):
     qb = QueryBuilder("company")
     qb.where("a").like("5")
     self._test_clause(qb, "a", "Like", "'5'")
示例#17
0
 def test_where_clause(self):
     qb = QueryBuilder("company")
     qb.where("a")
     self.assertEqual(qb.incomplete_filter_flag, True)
     self.assertEqual(len(qb.filters), 1)
     self.assertEqual(qb.filters[0], "a")
示例#18
0
 def test_gte_clause(self):
     qb = QueryBuilder('company')
     qb.where("a").gte("5")
     self._test_clause(qb, "a", ">=", "'5'")
示例#19
0
 def test_incomplete_where_clause_raises_error(self):
     qb = QueryBuilder("company")
     qb.where("a")
     self.assertRaisesRegexp(InvalidQueryError, r"Incomplete Filter Clause", qb.build)
示例#20
0
 def test_like_clause_raise_error_on_non_str(self):
     qb = QueryBuilder('company')
     qb.where("a")
     self.assertRaisesRegexp(InvalidQueryError, r"value be of type string",
                             qb.like, True)
示例#21
0
 def test_equal_clause_bool(self):
     qb = QueryBuilder("company")
     qb.where("a").equals(True)
     self._test_clause(qb, "a", "=", "true")
示例#22
0
 def _test_clause_chainable(self, clause, param, where=True):
     qb = QueryBuilder('company')
     if where:
         qb.where("a")
     ret = getattr(qb, clause)(param)
     self.assertEqual(qb, ret)
示例#23
0
 def test_equal_clause(self):
     qb = QueryBuilder("company")
     qb.where("a").equals("b")
     self._test_clause(qb, "a", "=", "'b'")
示例#24
0
 def test_select_columns_str(self):
     qb = QueryBuilder('company')
     columns = 'a,b'
     qb.select(columns)
     self.assertEqual(qb.columns, columns)
示例#25
0
 def test_get_entity(self):
     qb = QueryBuilder("company")
     entity = qb.get_entity()
     self.assertEqual(entity, "company")
示例#26
0
 def test_get_columns_specified(self):
     qb = QueryBuilder('company')
     columns = 'a, b'
     qb.select(columns)
     self.assertEqual(qb.get_columns(), columns)
示例#27
0
 def test_contains_clause_tuple(self):
     qb = QueryBuilder("company")
     values = (1, 2, 3)
     qb.where("a").contains(values)
     self._test_clause(qb, "a", "in", str(values))
示例#28
0
 def test_incomplete_where_clause_raises_error(self):
     qb = QueryBuilder('company')
     qb.where("a")
     self.assertRaisesRegexp(InvalidQueryError,
                             r'Incomplete Filter Clause', qb.build)
示例#29
0
 def test_contains_clause_raises_exception_str_value(self):
     qb = QueryBuilder("company")
     values = "fgf"
     qb = qb.where("a")
     self.assertRaisesRegexp(InvalidQueryError, "list/tuple of values", qb.contains, values)
示例#30
0
 def test_equal_clause_bool(self):
     qb = QueryBuilder('company')
     qb.where("a").equals(True)
     self._test_clause(qb, "a", '=', "true")
示例#31
0
 def test_get_entity(self):
     qb = QueryBuilder('company')
     entity = qb.get_entity()
     self.assertEqual(entity, 'company')
示例#32
0
 def test_contains_clause_tuple(self):
     qb = QueryBuilder('company')
     values = (1, 2, 3)
     qb.where('a').contains(values)
     self._test_clause(qb, "a", 'in', str(values))
示例#33
0
 def test_gte_clause(self):
     qb = QueryBuilder("company")
     qb.where("a").gte("5")
     self._test_clause(qb, "a", ">=", "'5'")