Initial import from Docker volume
This commit is contained in:
226
tests/test_model_index.py
Executable file
226
tests/test_model_index.py
Executable file
@@ -0,0 +1,226 @@
|
||||
# This file is part of Tryton. The COPYRIGHT file at the top level of this
|
||||
# repository contains the full copyright notices and license terms.
|
||||
|
||||
import unittest
|
||||
|
||||
from sql import Table
|
||||
|
||||
from trytond.model import Index
|
||||
|
||||
|
||||
class ModelIndexTestCase(unittest.TestCase):
|
||||
"Test Model Index"
|
||||
|
||||
def test_index_equality(self):
|
||||
"Test Index equality"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality(order='DESC')),
|
||||
(table1.amount, Index.Range()),
|
||||
where=table1.name == 'foo')
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality(order='DESC')),
|
||||
(table2.amount, Index.Range()),
|
||||
where=table2.name == 'foo')
|
||||
|
||||
self.assertEqual(index1, index2)
|
||||
|
||||
def test_index_equality_other(self):
|
||||
"test Index equality with other type"
|
||||
table = Table('test')
|
||||
index = Index(table)
|
||||
|
||||
self.assertEqual(index == 0, NotImplementedError)
|
||||
|
||||
def test_index_inequality_table(self):
|
||||
"Test Index inequality on table"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality()))
|
||||
table2 = Table('foo')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality()))
|
||||
|
||||
self.assertNotEqual(index1, index2)
|
||||
|
||||
def test_index_inequality_expression(self):
|
||||
"Test Index inequality on usage"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality()),
|
||||
(table1.amount, Index.Range()))
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality()),
|
||||
(table2.value, Index.Range()))
|
||||
|
||||
self.assertNotEqual(index1, index2)
|
||||
|
||||
def test_index_inequality_usage(self):
|
||||
"Test Index inequality on usage"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality()),
|
||||
(table1.amount, Index.Range()))
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality()),
|
||||
(table2.amount, Index.Similarity()))
|
||||
|
||||
self.assertNotEqual(index1, index2)
|
||||
|
||||
def test_index_inequality_usage_option(self):
|
||||
"Test Index inequality on usage option"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality(order='DESC')),
|
||||
(table1.amount, Index.Range()),
|
||||
where=table1.name == 'foo')
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality(order='ASC')),
|
||||
(table2.amount, Index.Range()),
|
||||
where=table2.name == 'foo')
|
||||
|
||||
self.assertNotEqual(index1, index2)
|
||||
|
||||
def test_index_inequality_option_expression(self):
|
||||
"Test Index inequality on option param"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality(order='DESC')),
|
||||
(table1.amount, Index.Range()),
|
||||
where=table1.name == 'foo')
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality(order='DESC')),
|
||||
(table2.amount, Index.Range()),
|
||||
where=table2.amount == 'foo')
|
||||
|
||||
self.assertNotEqual(index1, index2)
|
||||
|
||||
def test_index_inequality_option_param(self):
|
||||
"Test Index inequality on option param"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality(order='DESC')),
|
||||
(table1.amount, Index.Range()),
|
||||
where=table1.name == 'foo')
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality(order='DESC')),
|
||||
(table2.amount, Index.Range()),
|
||||
where=table2.name == 'bar')
|
||||
|
||||
self.assertEqual(index1, index2)
|
||||
|
||||
def test_index_subset(self):
|
||||
"Test Index subset"
|
||||
table = Table('test')
|
||||
index1 = Index(
|
||||
table,
|
||||
(table.foo, Index.Equality()))
|
||||
index2 = Index(
|
||||
table,
|
||||
(table.foo, Index.Equality()),
|
||||
(table.bar, Index.Equality()))
|
||||
|
||||
self.assertEqual(index1 < index2, True)
|
||||
self.assertEqual(index2 < index1, False)
|
||||
|
||||
def test_index_subset_expressions(self):
|
||||
"Test Index subset"
|
||||
table = Table('test')
|
||||
index1 = Index(
|
||||
table,
|
||||
(table.foo, Index.Equality()))
|
||||
index2 = Index(
|
||||
table,
|
||||
(table.bar, Index.Equality()),
|
||||
(table.foo, Index.Equality()))
|
||||
|
||||
self.assertEqual(index1 < index2, False)
|
||||
self.assertEqual(index2 < index1, False)
|
||||
|
||||
def test_index_subset_same(self):
|
||||
"Test Index subset"
|
||||
table = Table('test')
|
||||
index1 = Index(
|
||||
table,
|
||||
(table.foo, Index.Equality()))
|
||||
index2 = Index(
|
||||
table,
|
||||
(table.foo, Index.Equality()))
|
||||
|
||||
self.assertEqual(index1 < index2, False)
|
||||
self.assertEqual(index2 < index1, False)
|
||||
self.assertLessEqual(index1, index2)
|
||||
|
||||
def test_index_subset_other(self):
|
||||
"Test Index subset with other type"
|
||||
table = Table('test')
|
||||
index = Index(table)
|
||||
|
||||
self.assertEqual(index < 0, NotImplementedError)
|
||||
|
||||
def test_index_subset_table(self):
|
||||
"Test Index subset on different table"
|
||||
table1 = Table('foo')
|
||||
table2 = Table('bar')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality()))
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality()))
|
||||
|
||||
self.assertEqual(index1 < index2, False)
|
||||
self.assertEqual(index2 < index1, False)
|
||||
|
||||
def test_index_subset_options(self):
|
||||
"Test Index subset with different options"
|
||||
table1 = Table('foo')
|
||||
table2 = Table('bar')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality()),
|
||||
where=table1.name == 'bar')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality()),
|
||||
where=table2.name == 'foo')
|
||||
|
||||
self.assertEqual(index1 < index2, False)
|
||||
self.assertEqual(index2 < index1, False)
|
||||
|
||||
def test_index_hash(self):
|
||||
"Test Index hash"
|
||||
table1 = Table('test')
|
||||
index1 = Index(
|
||||
table1,
|
||||
(table1.name, Index.Equality(order='DESC')),
|
||||
(table1.amount, Index.Range()),
|
||||
where=table1.name == 'foo')
|
||||
table2 = Table('test')
|
||||
index2 = Index(
|
||||
table2,
|
||||
(table2.name, Index.Equality(order='DESC')),
|
||||
(table2.amount, Index.Range()),
|
||||
where=table2.name == 'foo')
|
||||
|
||||
self.assertEqual(hash(index1), hash(index2))
|
||||
Reference in New Issue
Block a user