-
Notifications
You must be signed in to change notification settings - Fork 12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: filter specific checks #150
base: main
Are you sure you want to change the base?
Conversation
@gkapfham i've been trying to fix the build for a couple weeks now and still can't figure it out. according to the workflow, there's something wrong with the here is the code block for the failure: =================================== FAILURES ===================================
___________ test_parse_config_gg_check_in_file_context_contains_file ___________
def test_parse_config_gg_check_in_file_context_contains_file():
"""Test to make sure that the file context is included in the GatorGrader arguments."""
# Given a configuration file with a GatorGrader check within a file context
config = Path("tests/input/yml_test_files/gatorgrade_one_gg_check_in_file.yml")
# When parse_config is run
output = parse_config(config)
# Then the file path should be in the GatorGrader arguments
> assert "file.py" in output[0].gg_args
E AttributeError: 'list' object has no attribute 'gg_args'
tests/input/test_input_gg_checks.py:17: AttributeError
=========================== short test summary info ============================
FAILED tests/input/test_input_gg_checks.py::test_parse_config_gg_check_in_file_context_contains_file - AttributeError: 'list' object has no attribute 'gg_args'
!!!!!!!!!!!!!!!!!!!!!!!!!! stopping after 1 failures !!!!!!!!!!!!!!!!!!!!!!!!!!!
============================== 1 failed in 0.39s ===============================
Error: Process completed with exit code 1. |
@Chezka109 Since this is failing/incomplete, consider marking this as a draft. |
Hello @Chezka109 can you please ensure that you first have reviews from two students who did not work on this feature and from at least one student technical leader? |
@Chezka109 do you now need reviews from TL's/other students? please add as reviewer if needed |
I tried to test this PR but I keep getting the error that there is no module called Here is a screenshot that shows that It's also worth considering that the package |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @Chezka109, I tried testing out your PR and it gives me this output:
hemanialaparthi@Hemanis-MacBook-Air exam % gatorgrade --check-include "Complete all TODOs"
Traceback (most recent call last):
File "/Users/hemanialaparthi/.local/bin/gatorgrade", line 7, in <module>
from gatorgrade.main import app
File "/Users/hemanialaparthi/Library/Application Support/pipx/venvs/gatorgrade/lib/python3.13/site-packages/gatorgrade/main.py", line 8, in <module>
from gatorgrade.input.parse_config import parse_config
File "/Users/hemanialaparthi/Library/Application Support/pipx/venvs/gatorgrade/lib/python3.13/site-packages/gatorgrade/input/parse_config.py", line 5, in <module>
from thefuzz import fuzz
ModuleNotFoundError: No module named 'thefuzz'
I would consider resolving this issue and also fixing the conflicts in the pyproject.toml
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This worked on my Linux computer.
Here is two screenshots of output from running different commands that @Chezka109 listed:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Filtering Specific Checks
Description
This feature adds the ability to filter GatorGrade results to show only the failing checks when running the command. By including a flag such as
--show-failures
, users will be able to see just the errors, which will make it easier to focus on the areas that need improvement without sifting through the passing checks. In addition to this, users can use the flag--check-include "{argument}"
to show only a specific check and--check-exclude "{argument}"
to remove specific checks when gatorgrade runs.Screenshots:
gatorgrade --show-failures
gatorgrade --check-include "Ensure that Question 1"
gatorgrade --check-exclude "Ensure that Question 1"
NOTE: Arguments for the
--check-include
and--check-exclude
uses fuzzy clustering. This means that:If a check appears as:
Complete all TODOs, remove the TODO markers, and rewrite comments for question_one.py
A user may write the command as any of the following:
gatorgrade --check-include "Complete all TODOs"
gatorgrade --check-include "Complete all todos"
gatorgrade --check-include "CompleTe all Todos"
gatorgrade --check-include "Co"
gatorgrade --check-include "TODO"
Linked Issues
closes: #139
Type of Change
Contributors
Reminder