From fe98bf06ef1ca119315c27f5c270aa368bb89e7d Mon Sep 17 00:00:00 2001 From: BJ Hargrave Date: Fri, 16 Aug 2024 10:54:27 -0400 Subject: [PATCH] lint: Disable line length lint check When using markdown tables in qna.yaml files, for example, in a knowledge context as copied from a source knowledge markdown file, the markdown table rows can be quite wide. Often much wider than the current 120 char line length limit. Since a markdown table row cannot be split without breaking the table, we need to disable line length checks to support the use of markdown tables in qna.yaml. Signed-off-by: BJ Hargrave --- src/instructlab/schema/taxonomy.py | 2 +- tests/test_parse.py | 26 ++++++++++++-------------- 2 files changed, 13 insertions(+), 15 deletions(-) diff --git a/src/instructlab/schema/taxonomy.py b/src/instructlab/schema/taxonomy.py index 9bcd22f..a3e9e14 100644 --- a/src/instructlab/schema/taxonomy.py +++ b/src/instructlab/schema/taxonomy.py @@ -30,7 +30,7 @@ DEFAULT_TAXONOMY_FOLDERS: list[str] = ["compositional_skills", "knowledge"] """Taxonomy folders which are also the schema names""" -DEFAULT_YAMLLINT_CONFIG: str = "{extends: relaxed, rules: {line-length: {max: 120}}}" +DEFAULT_YAMLLINT_CONFIG: str = "{extends: relaxed, rules: {line-length: disable}}" """Default yamllint configuration""" diff --git a/tests/test_parse.py b/tests/test_parse.py index d40d66f..e13e778 100644 --- a/tests/test_parse.py +++ b/tests/test_parse.py @@ -25,7 +25,7 @@ def test_invalid(self, caplog: pytest.LogCaptureFixture, testdata: pathlib.Path) parser = TaxonomyParser(schema_version=0, message_format=TaxonomyMessageFormat.LOGGING) taxonomy = parser.parse(rel_path) - assert_that(taxonomy.warnings).is_greater_than_or_equal_to(1) + assert_that(taxonomy.warnings).is_zero() assert_that(taxonomy.errors).is_greater_than_or_equal_to(2) assert_that(taxonomy.path.as_posix()).is_equal_to(test_yaml) assert_that(taxonomy.rel_path).is_equal_to(rel_path) @@ -33,10 +33,6 @@ def test_invalid(self, caplog: pytest.LogCaptureFixture, testdata: pathlib.Path) "message", filter=self.message_filter(f"{re.escape(test_yaml)}:"), ).is_length(len(caplog.records)) - assert_that(caplog.records).extracting( - "levelno", - filter=self.message_filter(r"line too long"), - ).contains_only(logging.WARNING) assert_that(caplog.records).extracting( "levelno", filter=self.message_filter(r"Unevaluated properties.*createdby"), @@ -47,9 +43,15 @@ def test_invalid(self, caplog: pytest.LogCaptureFixture, testdata: pathlib.Path) ).contains_only(logging.ERROR) def test_invalid_yamlint_strict(self, caplog: pytest.LogCaptureFixture, testdata: pathlib.Path) -> None: + yamllint_config = "{extends: relaxed, rules: {line-length: {max: 120}}}" test_yaml = "compositional_skills/invalid_yaml/qna.yaml" rel_path = testdata.joinpath(test_yaml) - parser = TaxonomyParser(schema_version=0, yamllint_strict=True, message_format=TaxonomyMessageFormat.LOGGING) + parser = TaxonomyParser( + schema_version=0, + message_format=TaxonomyMessageFormat.LOGGING, + yamllint_config=yamllint_config, + yamllint_strict=True, + ) taxonomy = parser.parse(rel_path) assert_that(taxonomy.warnings).is_zero() @@ -295,7 +297,7 @@ def test_version_1_as_version_2(self, caplog: pytest.LogCaptureFixture, testdata parser = TaxonomyParser(schema_version=2, message_format=TaxonomyMessageFormat.LOGGING) taxonomy = parser.parse(rel_path) - assert_that(taxonomy.warnings).is_greater_than_or_equal_to(1) + assert_that(taxonomy.warnings).is_zero() assert_that(taxonomy.errors).is_greater_than_or_equal_to(1) assert_that(taxonomy.path.as_posix()).is_equal_to(test_yaml) assert_that(taxonomy.rel_path).is_equal_to(rel_path) @@ -304,10 +306,6 @@ def test_version_1_as_version_2(self, caplog: pytest.LogCaptureFixture, testdata "message", filter=self.message_filter(f"{re.escape(test_yaml)}:"), ).is_length(len(caplog.records)) - assert_that(caplog.records).extracting( - "levelno", - filter=self.message_filter(r"line too long"), - ).contains_only(logging.WARNING) assert_that(caplog.records).extracting( "levelno", filter=self.message_filter(r"version.*required property"), @@ -321,7 +319,7 @@ def test_format_github(self, capsys: pytest.CaptureFixture[str], testdata: pathl parser = TaxonomyParser(schema_version=0, message_format=TaxonomyMessageFormat.GITHUB) taxonomy = parser.parse(rel_path) - assert_that(taxonomy.warnings).is_greater_than_or_equal_to(1) + assert_that(taxonomy.warnings).is_zero() assert_that(taxonomy.errors).is_greater_than_or_equal_to(2) assert_that(taxonomy.path.as_posix()).is_equal_to(test_yaml) assert_that(taxonomy.rel_path).is_equal_to(rel_path) @@ -340,7 +338,7 @@ def test_format_standard(self, capsys: pytest.CaptureFixture[str], testdata: pat parser = TaxonomyParser(schema_version=0, message_format=TaxonomyMessageFormat.STANDARD) taxonomy = parser.parse(rel_path) - assert_that(taxonomy.warnings).is_greater_than_or_equal_to(1) + assert_that(taxonomy.warnings).is_zero() assert_that(taxonomy.errors).is_greater_than_or_equal_to(2) assert_that(taxonomy.path.as_posix()).is_equal_to(test_yaml) assert_that(taxonomy.rel_path).is_equal_to(rel_path) @@ -359,7 +357,7 @@ def test_format_auto(self, capsys: pytest.CaptureFixture[str], testdata: pathlib parser = TaxonomyParser(schema_version=0) taxonomy = parser.parse(rel_path) - assert_that(taxonomy.warnings).is_greater_than_or_equal_to(1) + assert_that(taxonomy.warnings).is_zero() assert_that(taxonomy.errors).is_greater_than_or_equal_to(2) assert_that(taxonomy.path.as_posix()).is_equal_to(test_yaml) assert_that(taxonomy.rel_path).is_equal_to(rel_path)