2022.6 #88
@ -426,7 +426,7 @@ class PublisherService(PublisherABC):
|
|||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
self._env.set_working_directory(os.path.join(self._env.working_directory, '../'))
|
self._env.set_working_directory(os.path.join(self._env.working_directory, '../'))
|
||||||
self.exclude(f'*/{self._config.get_configuration("ProjectName")}.json')
|
self.exclude(f'*/{self._project_settings.name}.json')
|
||||||
self._output_path = os.path.abspath(os.path.join(self._output_path, self._project_settings.name, 'build'))
|
self._output_path = os.path.abspath(os.path.join(self._output_path, self._project_settings.name, 'build'))
|
||||||
|
|
||||||
Console.spinner('Reading source files:', self._read_sources, text_foreground_color=ForegroundColorEnum.green,
|
Console.spinner('Reading source files:', self._read_sources, text_foreground_color=ForegroundColorEnum.green,
|
||||||
@ -449,7 +449,7 @@ class PublisherService(PublisherABC):
|
|||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
self._env.set_working_directory(os.path.join(self._env.working_directory, '../'))
|
self._env.set_working_directory(os.path.join(self._env.working_directory, '../'))
|
||||||
self.exclude(f'*/{self._config.get_configuration("ProjectName")}.json')
|
self.exclude(f'*/{self._project_settings.name}.json')
|
||||||
self._output_path = os.path.abspath(os.path.join(self._output_path, self._project_settings.name, 'publish'))
|
self._output_path = os.path.abspath(os.path.join(self._output_path, self._project_settings.name, 'publish'))
|
||||||
|
|
||||||
Console.write_line('Build:')
|
Console.write_line('Build:')
|
||||||
|
@ -1,10 +1,88 @@
|
|||||||
|
import filecmp
|
||||||
|
import json
|
||||||
|
import os
|
||||||
|
import shutil
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
|
from cpl_core.utils import String
|
||||||
|
|
||||||
|
from unittests_cli.constants import PLAYGROUND_PATH
|
||||||
|
from unittests_shared.cli_commands import CLICommands
|
||||||
|
|
||||||
|
|
||||||
class BuildTestCase(unittest.TestCase):
|
class BuildTestCase(unittest.TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def __init__(self, methodName: str):
|
||||||
pass
|
unittest.TestCase.__init__(self, methodName)
|
||||||
|
self._source = 'build-test-source'
|
||||||
|
self._project_file = f'src/{String.convert_to_snake_case(self._source)}/{self._source}.json'
|
||||||
|
|
||||||
def test_equal(self):
|
def _get_project_settings(self):
|
||||||
pass
|
with open(os.path.join(os.getcwd(), self._project_file), 'r', encoding='utf-8') as cfg:
|
||||||
|
# load json
|
||||||
|
project_json = json.load(cfg)
|
||||||
|
cfg.close()
|
||||||
|
|
||||||
|
return project_json
|
||||||
|
|
||||||
|
def _save_project_settings(self, settings: dict):
|
||||||
|
with open(os.path.join(os.getcwd(), self._project_file), 'w', encoding='utf-8') as project_file:
|
||||||
|
project_file.write(json.dumps(settings, indent=2))
|
||||||
|
project_file.close()
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
os.chdir(os.path.abspath(PLAYGROUND_PATH))
|
||||||
|
# create projects
|
||||||
|
CLICommands.new('console', self._source, '--ab', '--s')
|
||||||
|
os.chdir(os.path.join(os.getcwd(), self._source))
|
||||||
|
|
||||||
|
def cleanUp(self):
|
||||||
|
# remove projects
|
||||||
|
if not os.path.exists(os.path.abspath(os.path.join(PLAYGROUND_PATH, self._source))):
|
||||||
|
return
|
||||||
|
|
||||||
|
shutil.rmtree(os.path.abspath(os.path.join(PLAYGROUND_PATH, self._source)))
|
||||||
|
|
||||||
|
def _are_dir_trees_equal(self, dir1, dir2):
|
||||||
|
"""
|
||||||
|
found at https://stackoverflow.com/questions/4187564/recursively-compare-two-directories-to-ensure-they-have-the-same-files-and-subdi
|
||||||
|
|
||||||
|
Compare two directories recursively. Files in each directory are
|
||||||
|
assumed to be equal if their names and contents are equal.
|
||||||
|
|
||||||
|
@param dir1: First directory path
|
||||||
|
@param dir2: Second directory path
|
||||||
|
|
||||||
|
@return: True if the directory trees are the same and
|
||||||
|
there were no errors while accessing the directories or files,
|
||||||
|
False otherwise.
|
||||||
|
"""
|
||||||
|
|
||||||
|
dirs_cmp = filecmp.dircmp(dir1, dir2)
|
||||||
|
if len(dirs_cmp.left_only) > 0 or len(dirs_cmp.right_only) > 0 or len(dirs_cmp.funny_files) > 0:
|
||||||
|
return False
|
||||||
|
|
||||||
|
(_, mismatch, errors) = filecmp.cmpfiles(dir1, dir2, dirs_cmp.common_files, shallow=False)
|
||||||
|
|
||||||
|
if len(mismatch) > 0 or len(errors) > 0:
|
||||||
|
return False
|
||||||
|
|
||||||
|
for common_dir in dirs_cmp.common_dirs:
|
||||||
|
new_dir1 = os.path.join(dir1, common_dir)
|
||||||
|
new_dir2 = os.path.join(dir2, common_dir)
|
||||||
|
if not self._are_dir_trees_equal(new_dir1, new_dir2):
|
||||||
|
return False
|
||||||
|
|
||||||
|
return True
|
||||||
|
|
||||||
|
def test_build(self):
|
||||||
|
CLICommands.build()
|
||||||
|
dist_path = './dist'
|
||||||
|
full_dist_path = f'{dist_path}/{self._source}/build/{String.convert_to_snake_case(self._source)}'
|
||||||
|
self.assertTrue(os.path.exists(dist_path))
|
||||||
|
self.assertTrue(os.path.exists(full_dist_path))
|
||||||
|
self.assertFalse(self._are_dir_trees_equal(f'./src/{String.convert_to_snake_case(self._source)}', full_dist_path))
|
||||||
|
with open(f'{full_dist_path}/{self._source}.json', 'w') as file:
|
||||||
|
file.write(json.dumps(self._get_project_settings(), indent=2))
|
||||||
|
file.close()
|
||||||
|
self.assertTrue(self._are_dir_trees_equal(f'./src/{String.convert_to_snake_case(self._source)}', full_dist_path))
|
||||||
|
@ -6,12 +6,14 @@ from typing import Optional
|
|||||||
from unittest import TestResult
|
from unittest import TestResult
|
||||||
|
|
||||||
from unittests_cli.add_test_case import AddTestCase
|
from unittests_cli.add_test_case import AddTestCase
|
||||||
|
from unittests_cli.build_test_case import BuildTestCase
|
||||||
from unittests_cli.constants import PLAYGROUND_PATH
|
from unittests_cli.constants import PLAYGROUND_PATH
|
||||||
from unittests_cli.generate_test_case import GenerateTestCase
|
from unittests_cli.generate_test_case import GenerateTestCase
|
||||||
from unittests_cli.install_test_case import InstallTestCase
|
from unittests_cli.install_test_case import InstallTestCase
|
||||||
from unittests_cli.new_test_case import NewTestCase
|
from unittests_cli.new_test_case import NewTestCase
|
||||||
from unittests_cli.remove_test_case import RemoveTestCase
|
from unittests_cli.remove_test_case import RemoveTestCase
|
||||||
from unittests_cli.uninstall_test_case import UninstallTestCase
|
from unittests_cli.uninstall_test_case import UninstallTestCase
|
||||||
|
from unittests_cli.update_test_case import UpdateTestCase
|
||||||
|
|
||||||
|
|
||||||
class CLITestSuite(unittest.TestSuite):
|
class CLITestSuite(unittest.TestSuite):
|
||||||
@ -21,36 +23,40 @@ class CLITestSuite(unittest.TestSuite):
|
|||||||
|
|
||||||
loader = unittest.TestLoader()
|
loader = unittest.TestLoader()
|
||||||
self._result: Optional[TestResult] = None
|
self._result: Optional[TestResult] = None
|
||||||
|
|
||||||
|
active_tests = [
|
||||||
# nothing needed
|
# nothing needed
|
||||||
self.addTests(loader.loadTestsFromTestCase(GenerateTestCase))
|
GenerateTestCase,
|
||||||
self.addTests(loader.loadTestsFromTestCase(NewTestCase))
|
NewTestCase,
|
||||||
|
|
||||||
# compare console output
|
# compare console output
|
||||||
# self.addTests(loader.loadTestsFromTestCase(VersionTestCase))
|
# VersionTestCase,
|
||||||
|
|
||||||
# project needed
|
# project needed
|
||||||
# compare two file states/directory content
|
# compare two file states/directory content
|
||||||
# self.addTests(loader.loadTestsFromTestCase(BuildTestCase))
|
BuildTestCase,
|
||||||
|
InstallTestCase,
|
||||||
self.addTests(loader.loadTestsFromTestCase(InstallTestCase))
|
|
||||||
|
|
||||||
# compare two file states/directory content
|
# compare two file states/directory content
|
||||||
# self.addTests(loader.loadTestsFromTestCase(PublishTestCase))
|
# PublishTestCase,
|
||||||
|
|
||||||
# check if application was executed properly
|
# check if application was executed properly
|
||||||
# self.addTests(loader.loadTestsFromTestCase(RunTestCase))
|
# RunTestCase,
|
||||||
|
|
||||||
# check if application was executed properly and file watcher is working
|
# check if application was executed properly and file watcher is working
|
||||||
# self.addTests(loader.loadTestsFromTestCase(StartTestCase))
|
# StartTestCase,
|
||||||
|
|
||||||
self.addTests(loader.loadTestsFromTestCase(UninstallTestCase))
|
|
||||||
|
|
||||||
|
UninstallTestCase,
|
||||||
# check in project settings if package is updated
|
# check in project settings if package is updated
|
||||||
# self.addTests(loader.loadTestsFromTestCase(UpdateTestCase))
|
# UpdateTestCase,
|
||||||
|
|
||||||
# workspace needed
|
# workspace needed
|
||||||
self.addTests(loader.loadTestsFromTestCase(AddTestCase))
|
AddTestCase,
|
||||||
self.addTests(loader.loadTestsFromTestCase(RemoveTestCase))
|
RemoveTestCase
|
||||||
|
]
|
||||||
|
|
||||||
|
for test in active_tests:
|
||||||
|
self.addTests(loader.loadTestsFromTestCase(test))
|
||||||
|
|
||||||
def _setup(self):
|
def _setup(self):
|
||||||
try:
|
try:
|
||||||
|
@ -21,6 +21,10 @@ class CLICommands:
|
|||||||
def add(cls, source: str, target: str):
|
def add(cls, source: str, target: str):
|
||||||
cls._run('add', source, target)
|
cls._run('add', source, target)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def build(cls):
|
||||||
|
cls._run('build')
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def generate(cls, schematic: str, name: str, output=False):
|
def generate(cls, schematic: str, name: str, output=False):
|
||||||
cls._run('generate', schematic, name, output=output)
|
cls._run('generate', schematic, name, output=output)
|
||||||
|
Loading…
Reference in New Issue
Block a user