Skip to content

Commit

Permalink
Parse the phpcs standards output a little better
Browse files Browse the repository at this point in the history
Resolves #185
  • Loading branch information
benmatselby committed Oct 15, 2023
1 parent 439b36c commit c4284e2
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 3 deletions.
2 changes: 1 addition & 1 deletion phpcs.py
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ def get_standards_available(self):
args.append("-i")

output = self.shell_out(args)
standards = output[35:].replace("and", ",").strip().split(", ")
standards = output[35:].replace(" and ", ", ").strip().split(", ")
return standards


Expand Down
16 changes: 14 additions & 2 deletions tests/test_phpcs.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,14 @@
import re
import sys
import sublime
from unittest import TestCase

from unittest import TestCase
from unittest.mock import patch

from Phpcs.phpcs import Sniffer


class TestDiffViewInternalFunctions(TestCase):
class TestSniffer(TestCase):
def test_we_can_build_up_the_correct_executable_string_when_we_prefix(self):
php_path = "/bin/php"
s = sublime.load_settings("phpcs.sublime-settings")
Expand All @@ -28,3 +29,14 @@ def test_we_can_build_up_the_correct_executable_string_when_we_dont_prefix(self)

args = Sniffer().get_executable_args()
self.assertIn("phpcs", args)

@patch("Phpcs.phpcs.Sniffer.shell_out")
def test_we_can_parse_phpcs_standards_output(self, shell_mock):
shell_mock.return_value = (
"The installed coding standards are One, NeutronStandard, Two and Three"
)
standards = Sniffer().get_standards_available()

expected = ["One", "NeutronStandard", "Two", "Three"]

self.assertEqual(expected, standards)

0 comments on commit c4284e2

Please sign in to comment.