コード例 #1
0
 def test_with_exist_file(self, file_path, current_cover,
                          expected_min_cover, tmpdir, monkeypatch):
     file_path = os.path.relpath(file_path)
     monkeypatch.chdir(tmpdir)
     cov_report = CoverageReport()
     cov_report._original_summary = {file_path: current_cover}
     assert cov_report.file_min_coverage(file_path) == expected_min_cover
コード例 #2
0
 def test_with_print_report(self, tmpdir, monkeypatch, caplog):
     monkeypatch.chdir(tmpdir)
     cov_report = CoverageReport()
     cov_report._report_str = Path(REPORT_STR_FILE).read_text()
     with caplog.at_level(logging.INFO, logger='demisto-sdk'):
         cov_report.coverage_report()
     assert caplog.records[
         0].msg == f'\n{Path(REPORT_STR_FILE).read_text()}'
コード例 #3
0
 def test_without_coverage_file(self, tmpdir, monkeypatch, caplog):
     monkeypatch.chdir(tmpdir)
     cov_report = CoverageReport()
     cov_report.cov
     os.remove(cov_report.coverage_file)
     with caplog.at_level(logging.DEBUG, logger='demisto-sdk'):
         cov_report.coverage_report()
     assert caplog.records[0]
コード例 #4
0
 def test_with_custom_epsilon_file(self, file_path, epsilon,
                                   expected_min_cover, tmpdir, monkeypatch):
     file_path = os.path.relpath(file_path)
     monkeypatch.chdir(tmpdir)
     cov_report = CoverageReport(
         allowed_coverage_degradation_percentage=epsilon)
     cov_report._original_summary = {file_path: 80.0}
     assert cov_report.file_min_coverage(file_path) == expected_min_cover
コード例 #5
0
 def test_with_json_min_report(self, tmpdir, monkeypatch, caplog):
     monkeypatch.chdir(tmpdir)
     coverage_path = os.path.join(COVERAGE_FILES_DIR,
                                  'HealthCheckAnalyzeLargeInvestigations')
     temp_cover_file = tmpdir.join('.coverage')
     copy_file(coverage_path, temp_cover_file)
     fix_file_path(temp_cover_file, PYTHON_FILE_PATH)
     cov_report = CoverageReport(report_dir=str(tmpdir),
                                 report_type='json,json-min',
                                 coverage_file=temp_cover_file)
     with caplog.at_level(logging.INFO, logger='demisto-sdk'):
         cov_report.coverage_report()
     # assert re.fullmatch(self.patern('json-min', 'coverage-min', 'json'), caplog.records[2].msg)
     assert os.path.exists(tmpdir.join('coverage-min.json'))
コード例 #6
0
 def test_files(self, tmpdir, monkeypatch):
     monkeypatch.chdir(tmpdir)
     coverage_path = os.path.join(COVERAGE_FILES_DIR,
                                  'HealthCheckAnalyzeLargeInvestigations')
     temp_coverage_path = tmpdir.join('.coverage')
     copy_file(coverage_path, temp_coverage_path)
     fix_file_path(temp_coverage_path, PYTHON_FILE_PATH)
     cov_report = CoverageReport(coverage_file=temp_coverage_path)
     cov_report._cov = get_coverage_obj(coverage_file=temp_coverage_path,
                                        report_dir=None,
                                        load_old=True)
     file_path, cover = list(cov_report.files.items())[0]
     assert os.path.abspath(file_path) == PYTHON_FILE_PATH
     assert isinstance(cover, float)
コード例 #7
0
 def test_get_report_str(self, tmpdir, monkeypatch):
     monkeypatch.chdir(tmpdir)
     coverage_path = os.path.join(COVERAGE_FILES_DIR,
                                  'HealthCheckAnalyzeLargeInvestigations')
     temp_coverage_path = tmpdir.join('.coverage')
     copy_file(coverage_path, temp_coverage_path)
     fix_file_path(temp_coverage_path, PYTHON_FILE_PATH)
     cov_report = CoverageReport(coverage_file=temp_coverage_path)
     cov_report._cov = get_coverage_obj(coverage_file=temp_coverage_path,
                                        report_dir=None,
                                        load_old=True)
     report_str = cov_report.report_str
     assert report_str.split('\n')[2].split() == [
         PYTHON_FILE_PATH, '38', '10', '73.68%'
     ]
コード例 #8
0
 def test_cov_creation(self, tmpdir, monkeypatch, mocker):
     monkeypatch.chdir(tmpdir)
     cov_report = CoverageReport()
     assert cov_report._cov is None
     get_coverage_obj_mock = mocker.patch(
         'demisto_sdk.commands.coverage_analyze.coverage_report.get_coverage_obj'
     )
     cov_report.cov
     assert cov_report._cov is not None
     get_coverage_obj_mock.assert_called_once()
コード例 #9
0
    def test_with_export_report_function(self, tmpdir, monkeypatch, caplog):
        monkeypatch.chdir(tmpdir)
        coverage_path = os.path.join(COVERAGE_FILES_DIR,
                                     'HealthCheckAnalyzeLargeInvestigations')
        temp_cover_file = tmpdir.join('.coverage')
        copy_file(coverage_path, temp_cover_file)
        fix_file_path(temp_cover_file, PYTHON_FILE_PATH)
        cov_report = CoverageReport(report_dir=str(tmpdir),
                                    report_type='html,json,xml',
                                    coverage_file=temp_cover_file)
        with caplog.at_level(logging.INFO, logger='demisto-sdk'):
            cov_report.coverage_report()

        assert re.fullmatch(self.patern('html', 'html/index', 'html'),
                            caplog.records[1].msg)
        assert re.fullmatch(self.patern('xml', 'coverage', 'xml'),
                            caplog.records[2].msg)
        assert re.fullmatch(self.patern('json', 'coverage', 'json'),
                            caplog.records[3].msg)
        assert len(caplog.records) == 4
コード例 #10
0
 def get_coverage_report_obj():
     cov_report = CoverageReport()
     cov_report._original_summary = read_file(JSON_MIN_DATA_FILE)['files']
     return cov_report
コード例 #11
0
 def test_with_new_file(self, file_path, default_min_cover, tmpdir,
                        monkeypatch):
     monkeypatch.chdir(tmpdir)
     cov_report = CoverageReport(default_min_coverage=default_min_cover)
     cov_report._original_summary = {}
     assert cov_report.file_min_coverage(file_path) == default_min_cover
コード例 #12
0
 def test_original_summary(self, tmpdir, monkeypatch, requests_mock):
     requests_mock.get(DEFAULT_URL, json=read_file(JSON_MIN_DATA_FILE))
     monkeypatch.chdir(tmpdir)
     assert CoverageReport().original_summary == read_file(
         JSON_MIN_DATA_FILE)['files']