Skip to content
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

add file-types flag #192

Open
wants to merge 16 commits into
base: main
Choose a base branch
from
Open

Conversation

gurukiran07
Copy link
Contributor

@gurukiran07 gurukiran07 commented Oct 25, 2024

closes #174

Added file-types flag to validator. file-types and exclude-file-types are mutually exclusive. if file-type is set then builds a list of files that can be excluded and sets that value to exclude-file-types flag.

Some rudimentary tests:

with --file-types=yaml
image

with --exclude-file-types and --file-types
image

@kehoecj kehoecj added hacktoberfest-accepted Valid PR Hacktoberfest PR hacktoberfest 🎃 Hacktoberfest 2024 waiting-on-maintainer-review PR is waiting to be reviewed and functionally tested by the maintainers pr-action-requested PR is awaiting feedback from the submitting developer and removed waiting-on-maintainer-review PR is waiting to be reviewed and functionally tested by the maintainers labels Oct 25, 2024
@kehoecj kehoecj self-requested a review October 25, 2024 14:50
Copy link
Collaborator

@kehoecj kehoecj left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. Add unit tests for your changes
  2. Fix issues identified in failed jobs: golangci-lint and goreportcard

cmd/validator/validator.go Outdated Show resolved Hide resolved
@gurukiran07 gurukiran07 requested a review from kehoecj October 25, 2024 17:14
@kehoecj kehoecj added waiting-on-maintainer-review PR is waiting to be reviewed and functionally tested by the maintainers and removed pr-action-requested PR is awaiting feedback from the submitting developer labels Oct 25, 2024
@gurukiran07
Copy link
Contributor Author

  1. Add unit tests for your changes
  2. Fix issues identified in failed jobs: golangci-lint and goreportcard

Done. Pipeline's green. Let me know if there's anything else I need to do. @kehoecj

@kehoecj
Copy link
Collaborator

kehoecj commented Oct 28, 2024

@gurukiran07 Please resolve conflicts then I think you're good to go

@kehoecj kehoecj added pr-action-requested PR is awaiting feedback from the submitting developer and removed waiting-on-maintainer-review PR is waiting to be reviewed and functionally tested by the maintainers labels Oct 28, 2024
@gurukiran07
Copy link
Contributor Author

@gurukiran07 Please resolve conflicts then I think you're good to go

Done.

cmd/validator/validator.go Outdated Show resolved Hide resolved
cmd/validator/validator.go Outdated Show resolved Hide resolved
cmd/validator/validator.go Outdated Show resolved Hide resolved
cmd/validator/validator.go Outdated Show resolved Hide resolved
cmd/validator/validator.go Outdated Show resolved Hide resolved
@gurukiran07
Copy link
Contributor Author

Will make the requested changes when I get some time today.

@kehoecj
Copy link
Collaborator

kehoecj commented Oct 30, 2024

@gurukiran07 Please resolve conflicts and I'll work on getting this merged today

@gurukiran07
Copy link
Contributor Author

@gurukiran07 Please resolve conflicts and I'll work on getting this merged today

@kehoecj Done. Fixed the conflicts.

Some basic testing:

  • with both exclude-file-types and file-types
image
  • with just file-types
image
  • with just exclude-file-types
image

@gurukiran07 gurukiran07 requested a review from ccoVeille October 30, 2024 15:33
cmd/validator/validator.go Outdated Show resolved Hide resolved
cmd/validator/validator.go Outdated Show resolved Hide resolved
Comment on lines 338 to 352
for _, t := range filetype.FileTypes {
validTypes = append(validTypes, t.Name)
}

validExcludeTypes := misc.ArrToMap(validTypes...)

for _, t := range strings.Split(*fileTypesPtr, ",") {
delete(validExcludeTypes, t)
}

excludeFileTypes := make([]string, 0, len(validExcludeTypes))

for fileType := range validExcludeTypes {
excludeFileTypes = append(excludeFileTypes, fileType)
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks complicated

Isn't something that could be used in Go standard "slice" package

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I couldn't anything useful in slices packages that can be used here. Would adding comments make it more readable? @ccoVeille

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agreed - I think this can be simplified a bit

Copy link
Contributor Author

@gurukiran07 gurukiran07 Oct 31, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Refactored it to use slices.DeleteFunc.
@ccoVeille @kehoecj

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks, as you can see the code is now way clearer

@@ -162,6 +168,10 @@ Supported formats: standard, json, junit (default: "standard")`,
}
}

if err := buildExcludeFileTypesFromFileTypes(excludeFileTypesPtr, fileTypesPtr); err != nil {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

BTW @kehoecj is there a way to validate the behavior of exclusive exclusion (cannot use filter + exclusion) for types in the tests?

Or the code needs to be refactored a lot?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should be possible to validate in testing.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Then I think it should be part of the PR

cmd/validator/validator.go Outdated Show resolved Hide resolved
@gurukiran07 gurukiran07 requested a review from kehoecj October 30, 2024 18:25
@gurukiran07 gurukiran07 requested a review from ccoVeille October 31, 2024 16:33
Copy link
Contributor

@ccoVeille ccoVeille left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you think you could add the tests I'm talking about here

#192 (comment)

@gurukiran07
Copy link
Contributor Author

Do you think you could add the tests I'm talking about here

#192 (comment)

Yeah I can. Will work on it when I get some time.

@kehoecj
Copy link
Collaborator

kehoecj commented Dec 17, 2024

@gurukiran07 Please resolve conflicts

@@ -344,6 +363,22 @@ func setFlagFromEnvIfNotSet(flagName string, envVar string) error {
return nil
}

// Build exclude-file-type list from file-type values
func getExcludeFileTypesFromFileTypes(fileTypesPtr *string) string {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
func getExcludeFileTypesFromFileTypes(fileTypesPtr *string) string {
func getExcludeFileTypes(fileTypesPtr *string) string {

@kehoecj
Copy link
Collaborator

kehoecj commented Dec 18, 2024

@gurukiran07 We probably want this to also be mutually exclusive with the new globbing functionality

@kehoecj
Copy link
Collaborator

kehoecj commented Jan 20, 2025

@gurukiran07 I would like to get this merged in. Can you please take a look at several outstanding comments?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
hacktoberfest 🎃 Hacktoberfest 2024 hacktoberfest-accepted Valid PR Hacktoberfest PR pr-action-requested PR is awaiting feedback from the submitting developer
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add --file-types flag to include only specified config file types
3 participants