From 45962a05da1b61696004ca9acf3afb15d6adefbf Mon Sep 17 00:00:00 2001 From: Bob Feng Date: Wed, 13 Jan 2021 17:33:04 +0800 Subject: BaseTools: Add unittest for Split tool REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3165 This patch is to add the unit test for Split python tool Signed-off-by: Bob Feng Cc: Liming Gao Cc: Yuwei Chen Reviewed-by: Liming Gao Reviewed-by: Yuwei Chen --- BaseTools/Source/Python/tests/Split/test_split.py | 111 ++++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 BaseTools/Source/Python/tests/Split/test_split.py (limited to 'BaseTools/Source') diff --git a/BaseTools/Source/Python/tests/Split/test_split.py b/BaseTools/Source/Python/tests/Split/test_split.py new file mode 100644 index 0000000000..82f71ecf53 --- /dev/null +++ b/BaseTools/Source/Python/tests/Split/test_split.py @@ -0,0 +1,111 @@ +# @file +# Split a file into two pieces at the request offset. +# +# Copyright (c) 2021, Intel Corporation. All rights reserved.
+# +# SPDX-License-Identifier: BSD-2-Clause-Patent +# +## + +# Import Modules +import unittest +import tempfile +import os +import shutil +import Split.Split as sp +import struct as st + + +class TestSplit(unittest.TestCase): + def setUp(self): + self.WORKSPACE = tempfile.mkdtemp() + self.binary_file = os.path.join(self.WORKSPACE, "Binary.bin") + self.create_inputfile() + + def tearDown(self): + if os.path.exists(self.WORKSPACE): + shutil.rmtree(self.WORKSPACE) + + def test_splitFile_position(self): + position = [-1, 0, 256, 512, 700, 1024, 2048] + result = [(0, 1024), (0, 1024), (256, 768), + (512, 512), (700, 324), (1024, 0), (1024, 0)] + for index, po in enumerate(position): + try: + sp.splitFile(self.binary_file, po) + except Exception as e: + self.assertTrue(False, msg="splitFile function error") + + output1 = os.path.join(self.WORKSPACE, "Binary.bin1") + output2 = os.path.join(self.WORKSPACE, "Binary.bin2") + with open(output1, "rb") as f1: + size1 = len(f1.read()) + with open(output2, "rb") as f2: + size2 = len(f2.read()) + + ex_result = result[index] + self.assertEqual(size1, ex_result[0]) + self.assertEqual(size2, ex_result[1]) + + def create_inputfile(self): + with open(self.binary_file, "wb") as fout: + for i in range(512): + fout.write(st.pack("