|
|
@@ -1,13 +1,7 @@
|
|
|
#!/usr/bin/env python
|
|
|
from __future__ import print_function, division
|
|
|
import unittest
|
|
|
-import struct
|
|
|
-import csv
|
|
|
import sys
|
|
|
-import subprocess
|
|
|
-import tempfile
|
|
|
-import os
|
|
|
-import StringIO
|
|
|
|
|
|
try:
|
|
|
import efuse_table_gen
|
|
|
@@ -33,13 +27,13 @@ name2, EFUSE_BLK3, 5,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].efuse_block, 'EFUSE_BLK3')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 5)
|
|
|
self.assertEqual(t[0].comment, 'Use for test name 1')
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].efuse_block, 'EFUSE_BLK3')
|
|
|
self.assertEqual(t[1].bit_start, 5)
|
|
|
@@ -54,11 +48,11 @@ name2, EFUSE_BLK3, ,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].bit_start, 5)
|
|
|
self.assertEqual(t[1].bit_count, 4)
|
|
|
@@ -71,11 +65,11 @@ name2, EFUSE_BLK2, ,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].bit_start, 0)
|
|
|
self.assertEqual(t[1].bit_count, 4)
|
|
|
@@ -90,15 +84,15 @@ name3, EFUSE_BLK2, 5,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].bit_start, 0)
|
|
|
self.assertEqual(t[1].bit_count, 4)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[2].field_name, 'name3')
|
|
|
self.assertEqual(t[2].bit_start, 5)
|
|
|
self.assertEqual(t[2].bit_count, 4)
|
|
|
@@ -112,7 +106,7 @@ name2, EFUSE_BLK2, ,
|
|
|
name1, EFUSE_BLK3, , 5,
|
|
|
"""
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "Field names must be unique"):
|
|
|
- t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
+ efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
|
|
|
def test_seq_bit_start5_fill(self):
|
|
|
csv = """
|
|
|
@@ -124,19 +118,19 @@ name3, EFUSE_BLK3, 5,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].bit_start, 0)
|
|
|
self.assertEqual(t[1].bit_count, 4)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[2].field_name, 'name2')
|
|
|
self.assertEqual(t[2].bit_start, 4)
|
|
|
self.assertEqual(t[2].bit_count, 4)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[3].field_name, 'name3')
|
|
|
self.assertEqual(t[3].bit_start, 5)
|
|
|
self.assertEqual(t[3].bit_count, 5)
|
|
|
@@ -158,7 +152,7 @@ name2, EFUSE_BLK3, 5,
|
|
|
name2, EFUSE_BLK2, , 4,
|
|
|
"""
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "missing field name"):
|
|
|
- t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
+ efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
|
|
|
def test_unique_field_name_fail(self):
|
|
|
csv = """
|
|
|
@@ -167,7 +161,7 @@ name1, EFUSE_BLK3, 0,
|
|
|
name1, EFUSE_BLK3, 5, 4, Use for test name 2
|
|
|
"""
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "Field names must be unique"):
|
|
|
- t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
+ efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
|
|
|
def test_bit_count_empty_fail(self):
|
|
|
csv = """
|
|
|
@@ -176,7 +170,7 @@ name1, EFUSE_BLK3, 0,
|
|
|
name2, EFUSE_BLK3, 5, 4, Use for test name 2
|
|
|
"""
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "empty"):
|
|
|
- t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
+ efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
|
|
|
def test_bit_start_num_fail(self):
|
|
|
csv = """
|
|
|
@@ -185,7 +179,7 @@ name1, EFUSE_BLK3, k,
|
|
|
name2, EFUSE_BLK3, 5, 4, Use for test name 2
|
|
|
"""
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "Invalid field value"):
|
|
|
- t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
+ efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
|
|
|
def test_join_entry(self):
|
|
|
csv = """
|
|
|
@@ -198,27 +192,27 @@ name4, EFUSE_BLK2, 30,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].efuse_block, 'EFUSE_BLK2')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 6)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].efuse_block, 'EFUSE_BLK2')
|
|
|
self.assertEqual(t[1].bit_start, 6)
|
|
|
self.assertEqual(t[1].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[2].field_name, 'name3')
|
|
|
self.assertEqual(t[2].efuse_block, 'EFUSE_BLK3')
|
|
|
self.assertEqual(t[2].bit_start, 20)
|
|
|
self.assertEqual(t[2].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[3].field_name, 'name3')
|
|
|
self.assertEqual(t[3].efuse_block, 'EFUSE_BLK3')
|
|
|
self.assertEqual(t[3].bit_start, 30)
|
|
|
self.assertEqual(t[3].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[4].field_name, 'name4')
|
|
|
self.assertEqual(t[4].efuse_block, 'EFUSE_BLK2')
|
|
|
self.assertEqual(t[4].bit_start, 30)
|
|
|
@@ -231,7 +225,7 @@ name1, EFUSE_BLK5, 0,
|
|
|
name2, EFUSE_BLK3, 5, 4, Use for test name 2
|
|
|
"""
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "'efuse_block' should consist from EFUSE_BLK0..EFUSE_BLK3"):
|
|
|
- t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
+ efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
|
|
|
def test_field_size_is_ok(self):
|
|
|
csv = """
|
|
|
@@ -239,7 +233,7 @@ name2, EFUSE_BLK3, 5,
|
|
|
name1, EFUSE_BLK0, 0, 224, Use for test name 1
|
|
|
name2, EFUSE_BLK1, 0, 256, Use for test name 2
|
|
|
"""
|
|
|
- efuse_table_gen.coding_scheme = 0 # NONE
|
|
|
+ efuse_table_gen.coding_scheme = 0 # NONE
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
|
|
|
@@ -249,7 +243,7 @@ name2, EFUSE_BLK1, 0,
|
|
|
name1, EFUSE_BLK3, 190, 1, Use for test name 1
|
|
|
name2, EFUSE_BLK3, 191, 5, Use for test name 2
|
|
|
"""
|
|
|
- efuse_table_gen.coding_scheme = 1 #3/4 coding
|
|
|
+ efuse_table_gen.coding_scheme = 1 # 3/4 coding
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "The field is outside the boundaries"):
|
|
|
t.verify()
|
|
|
@@ -266,7 +260,7 @@ name2, EFUSE_BLK1, 1,
|
|
|
|
|
|
|
|
|
class VerificationTests(unittest.TestCase):
|
|
|
-
|
|
|
+
|
|
|
def test_general(self):
|
|
|
csv = """
|
|
|
# field_name, efuse_block(EFUSE_BLK0..EFUSE_BLK3), bit_start(0..255), bit_count, comment
|
|
|
@@ -277,22 +271,22 @@ name2_1, EFUSE_BLK2, 5,
|
|
|
"""
|
|
|
t = efuse_table_gen.FuseTable.from_csv(csv)
|
|
|
t.verify()
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[0].field_name, 'name1')
|
|
|
self.assertEqual(t[0].efuse_block, 'EFUSE_BLK3')
|
|
|
self.assertEqual(t[0].bit_start, 0)
|
|
|
self.assertEqual(t[0].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[1].field_name, 'name2')
|
|
|
self.assertEqual(t[1].efuse_block, 'EFUSE_BLK3')
|
|
|
self.assertEqual(t[1].bit_start, 5)
|
|
|
self.assertEqual(t[1].bit_count, 4)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[2].field_name, 'name1_1')
|
|
|
self.assertEqual(t[2].efuse_block, 'EFUSE_BLK2')
|
|
|
self.assertEqual(t[2].bit_start, 0)
|
|
|
self.assertEqual(t[2].bit_count, 5)
|
|
|
-
|
|
|
+
|
|
|
self.assertEqual(t[3].field_name, 'name2_1')
|
|
|
self.assertEqual(t[3].efuse_block, 'EFUSE_BLK2')
|
|
|
self.assertEqual(t[3].bit_start, 5)
|
|
|
@@ -317,7 +311,7 @@ name2, EFUSE_BLK2, 5,
|
|
|
common_table = efuse_table_gen.FuseTable.from_csv(csv_common)
|
|
|
common_table.verify("common_table")
|
|
|
two_tables = common_table
|
|
|
-
|
|
|
+
|
|
|
csv_custom = """
|
|
|
# field_name, efuse_block(EFUSE_BLK0..EFUSE_BLK3), bit_start(0..255), bit_count, comment
|
|
|
name3, EFUSE_BLK3, 20, 5, Use for test name 1
|
|
|
@@ -325,10 +319,11 @@ name4, EFUSE_BLK3, 4,
|
|
|
"""
|
|
|
custom_table = efuse_table_gen.FuseTable.from_csv(csv_custom)
|
|
|
custom_table.verify("custom_table")
|
|
|
-
|
|
|
+
|
|
|
two_tables += custom_table
|
|
|
with self.assertRaisesRegexp(efuse_table_gen.InputError, "overlaps"):
|
|
|
two_tables.verify()
|
|
|
|
|
|
+
|
|
|
if __name__ == "__main__":
|
|
|
unittest.main()
|