code_ownership 2.1.1 → 2.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.cargo/config +2 -2
- data/Cargo.lock +2 -2
- data/README.md +8 -8
- data/ext/cargo-vendor/codeowners-0.3.2/.cargo-checksum.json +1 -0
- data/ext/cargo-vendor/codeowners-0.3.2/.github/CODEOWNERS +1 -0
- data/ext/cargo-vendor/codeowners-0.3.2/AGENTS.md +38 -0
- data/ext/cargo-vendor/codeowners-0.3.2/CLAUDE.md +1 -0
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/Cargo.lock +1 -1
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/Cargo.toml +17 -1
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/README.md +11 -1
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/cli.rs +9 -5
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/config.rs +81 -1
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/crosscheck.rs +5 -8
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/codeowners_file_parser.rs +3 -3
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/file_owner_resolver.rs +3 -1
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/package_mapper.rs +2 -2
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper.rs +2 -2
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/validator.rs +15 -10
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership.rs +1 -0
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/project.rs +3 -0
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/project_builder.rs +111 -44
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/runner/api.rs +7 -6
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/runner/types.rs +2 -1
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/runner.rs +67 -16
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/tracked_files.rs +29 -1
- data/ext/cargo-vendor/codeowners-0.3.2/tests/codeowners_path_test.rs +92 -0
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/common/mod.rs +2 -1
- data/ext/cargo-vendor/codeowners-0.3.2/tests/executable_name_config_test.rs +67 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_codeowners_path/config/code_ownership.yml +11 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_codeowners_path/config/teams/test_team.yml +6 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_codeowners_path/docs/CODEOWNERS +14 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_codeowners_path/expected/CODEOWNERS +14 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_codeowners_path/ruby/app/models/test.rb +3 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/.github/CODEOWNERS +10 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/app/foo.rb +3 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/config/code_ownership.yml +4 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/config/teams/foo.yml +5 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/config/teams/payments.yml +6 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/ruby/app/payments/foo.rb +4 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/default_executable_name/.github/CODEOWNERS +11 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/default_executable_name/app/bar.rb +3 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/default_executable_name/config/code_ownership.yml +5 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/default_executable_name/config/teams/bar.yml +5 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/missing_github_team/.github/CODEOWNERS +10 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/missing_github_team/config/code_ownership.yml +10 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/missing_github_team/config/teams/bad_team.yml +1 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/missing_github_team/config/teams/good.yml +3 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/valid_project/gems/pets/dog.rb +5 -0
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/git_stage_test.rs +4 -1
- data/ext/cargo-vendor/codeowners-0.3.2/tests/missing_github_team_test.rs +23 -0
- data/ext/cargo-vendor/codeowners-0.3.2/tests/run_config_executable_override_test.rs +98 -0
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/runner_api.rs +8 -4
- data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/valid_project_test.rs +3 -3
- data/ext/cargo-vendor/codeowners-0.3.2/tests/validate_files_test.rs +378 -0
- data/ext/cargo-vendor/unicode-ident-1.0.19/.cargo-checksum.json +1 -1
- data/ext/code_ownership/Cargo.toml +1 -1
- data/ext/code_ownership/src/lib.rs +2 -2
- data/lib/code_ownership/private/file_path_finder.rb +19 -3
- data/lib/code_ownership/private/team_finder.rb +1 -2
- data/lib/code_ownership/version.rb +1 -1
- data/lib/code_ownership.rb +2 -0
- metadata +178 -152
- data/ext/cargo-vendor/codeowners-0.3.0/.cargo-checksum.json +0 -1
- data/ext/cargo-vendor/codeowners-0.3.0/tests/validate_files_test.rs +0 -144
- data/ext/cargo-vendor/unicode-ident-1.0.19/tests/fst/.gitignore +0 -1
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/.github/workflows/audit.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/.github/workflows/ci.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/.github/workflows/dotslash-config.json +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/.rustfmt.toml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/.rusty-hook.toml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/dev/run_benchmarks_for_file.sh +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/dev/run_benchmarks_for_gv.sh +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/rust-toolchain.toml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/cache/file.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/cache/mod.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/cache/noop.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/common_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/lib.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/main.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/codeowners_query.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/file_generator.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/file_owner_finder.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/annotated_file_mapper.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/directory_mapper.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/escaper.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/team_gem_mapper.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/team_glob_mapper.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/ownership/mapper/team_yml_mapper.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/path_utils.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/src/project_file_builder.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/cache_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/crosscheck_owners_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/.github/CODEOWNERS +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/config/code_ownership.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/config/teams/payments.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/config/teams/payroll.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/gems/payroll_calculator/calculator.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/models/bank_account.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/models/blockchain.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/models/payroll.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/payments/nacha.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/services/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/services/multi_owned.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/app/unowned.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/invalid_project/ruby/packages/payroll_flow/package.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/.github/CODEOWNERS +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/.keep +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/config/code_ownership.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/config/teams/design.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/config/teams/frontend.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/frontend/apps/public/index.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/frontend/packages/dashboard/package.json +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/frontend/packages/dashboard/src/index.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/frontend/packages/ui-kit/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/javascript_only_project/frontend/packages/ui-kit/src/button.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0/tests/fixtures/valid_project → codeowners-0.3.2/tests/fixtures/missing_github_team}/gems/pets/dog.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/.github/CODEOWNERS +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/app/consumers/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/app/consumers/deep/nesting/nestdir/deep_file.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/app/consumers/one_owner.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/app/services/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/app/services/exciting/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/app/services/exciting/some_other_file.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/config/code_ownership.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/config/teams/bar.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/multiple-directory-owners/config/teams/foo.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/.github/CODEOWNERS +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/.ignore +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/config/code_ownership.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/config/teams/payments.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/config/teams/payroll.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/config/teams/ux.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/gems/payroll_calculator/calculator.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/PayrollFlow/index.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/PayrollFlow/package.json +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/items/(special)/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/items/(special)/pay.ts +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/items/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/items/item.ts +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/javascript/packages/list/page-admin.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/models/bank_account.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/models/payroll.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/payments/foo/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/payments/foo/ownedby_payroll.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/payments/nacha.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/payroll/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/payroll/payroll.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/views/foos/edit.erb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/views/foos/index.html.erb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/app/views/foos/new.html.erb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/ignored_files/git_ignored.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/ruby/packages/payroll_flow/package.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project/should_be_ignored/an_ignored_file.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/.github/CODEOWNERS +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/config/code_ownership.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/config/teams/brewers.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/config/teams/cubs.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/config/teams/giants.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/config/teams/rockies.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/datepicker/package.json +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/datepicker/src/picks/dp.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/list/package.json +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/list/src/item.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/textfield/package.json +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/textfield/src/field.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/frontend/packages/components/textfield/src/fields/small.tsx +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/gems/apollo/lib/apollo.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/gems/ivy/lib/ivy.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/gems/lager/lib/lager.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/gems/summit/lib/summit.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/packs/games/app/services/stats.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/packs/games/package.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/packs/locations/app/services/capacity.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/packs/locations/package.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/packs/schedule/app/services/date.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/packs/schedule/package.yml +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/brewers/lib/util.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/brewers/services/play.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/models/.codeowner +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/models/db/price.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/models/entertainment.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/cubs/services/play.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/giants/services/play.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/fixtures/valid_project_with_overrides/ruby/app/rockies/services/play.rb +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/invalid_project_structure_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/invalid_project_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/multiple_directory_owners_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/untracked_files_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tests/valid_project_with_overrides_test.rs +0 -0
- /data/ext/cargo-vendor/{codeowners-0.3.0 → codeowners-0.3.2}/tmp/.gitkeep +0 -0
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
# STOP! - DO NOT EDIT THIS FILE MANUALLY
|
|
2
|
+
# This file was automatically generated by "bin/codeownership validate".
|
|
3
|
+
#
|
|
4
|
+
# CODEOWNERS is used for GitHub to suggest code/file owners to various GitHub
|
|
5
|
+
# teams. This is useful when developers create Pull Requests since the
|
|
6
|
+
# code/file owner is notified. Reference GitHub docs for more details:
|
|
7
|
+
# https://help.github.com/en/articles/about-code-owners
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
# Annotations at the top of file
|
|
11
|
+
/ruby/app/models/test.rb @TestTeam
|
|
12
|
+
|
|
13
|
+
# Team YML ownership
|
|
14
|
+
/config/teams/test_team.yml @TestTeam
|
data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_codeowners_path/expected/CODEOWNERS
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
# STOP! - DO NOT EDIT THIS FILE MANUALLY
|
|
2
|
+
# This file was automatically generated by "bin/codeownership validate".
|
|
3
|
+
#
|
|
4
|
+
# CODEOWNERS is used for GitHub to suggest code/file owners to various GitHub
|
|
5
|
+
# teams. This is useful when developers create Pull Requests since the
|
|
6
|
+
# code/file owner is notified. Reference GitHub docs for more details:
|
|
7
|
+
# https://help.github.com/en/articles/about-code-owners
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
# Annotations at the top of file
|
|
11
|
+
/ruby/app/models/test.rb @TestTeam
|
|
12
|
+
|
|
13
|
+
# Team YML ownership
|
|
14
|
+
/config/teams/test_team.yml @TestTeam
|
data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/custom_executable_name/.github/CODEOWNERS
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
# STOP! - DO NOT EDIT THIS FILE MANUALLY
|
|
2
|
+
# This file was automatically generated by "codeowners".
|
|
3
|
+
#
|
|
4
|
+
# CODEOWNERS is used for GitHub to suggest code/file owners to various GitHub
|
|
5
|
+
# teams. This is useful when developers create Pull Requests since the
|
|
6
|
+
# code/file owner is notified. Reference GitHub docs for more details:
|
|
7
|
+
# https://help.github.com/en/articles/about-code-owners
|
|
8
|
+
|
|
9
|
+
# Outdated content to trigger validation error
|
|
10
|
+
/app/old.rb @FooTeam
|
data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/default_executable_name/.github/CODEOWNERS
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
# STOP! - DO NOT EDIT THIS FILE MANUALLY
|
|
2
|
+
# This file was automatically generated by "codeowners".
|
|
3
|
+
#
|
|
4
|
+
# CODEOWNERS is used for GitHub to suggest code/file owners to various GitHub
|
|
5
|
+
# teams. This is useful when developers create Pull Requests since the
|
|
6
|
+
# code/file owner is notified. Reference GitHub docs for more details:
|
|
7
|
+
# https://help.github.com/en/articles/about-code-owners
|
|
8
|
+
|
|
9
|
+
# Outdated content to trigger validation error
|
|
10
|
+
/app/old.rb @BarTeam
|
|
11
|
+
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
# STOP! - DO NOT EDIT THIS FILE MANUALLY
|
|
2
|
+
# This file was automatically generated by "bin/codeownership validate".
|
|
3
|
+
#
|
|
4
|
+
# CODEOWNERS is used for GitHub to suggest code/file owners to various GitHub
|
|
5
|
+
# teams. This is useful when developers create Pull Requests since the
|
|
6
|
+
# code/file owner is notified. Reference GitHub docs for more details:
|
|
7
|
+
# https://help.github.com/en/articles/about-code-owners
|
|
8
|
+
|
|
9
|
+
# Match all files to GoodTeam so for-file --from-codeowners hits the parser path
|
|
10
|
+
* @GoodTeam
|
data/ext/cargo-vendor/codeowners-0.3.2/tests/fixtures/missing_github_team/config/teams/bad_team.yml
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
name: MissingGithub
|
|
@@ -38,7 +38,10 @@ where
|
|
|
38
38
|
let result = func(&run_config, stage);
|
|
39
39
|
assert_no_run_errors(&result);
|
|
40
40
|
|
|
41
|
-
assert!(
|
|
41
|
+
assert!(
|
|
42
|
+
run_config.codeowners_file_path.as_ref().unwrap().exists(),
|
|
43
|
+
"CODEOWNERS file was not created",
|
|
44
|
+
);
|
|
42
45
|
let staged = is_file_staged(&run_config.project_root, CODEOWNERS_REL);
|
|
43
46
|
assert_eq!(staged, expected_staged, "unexpected staged state for CODEOWNERS");
|
|
44
47
|
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
use predicates::prelude::*;
|
|
2
|
+
use std::error::Error;
|
|
3
|
+
|
|
4
|
+
mod common;
|
|
5
|
+
use common::OutputStream;
|
|
6
|
+
use common::run_codeowners;
|
|
7
|
+
|
|
8
|
+
// Exercise the code path that skips invalid team files and prints to stderr
|
|
9
|
+
// (codeowners_file_parser::teams_by_github_team_name). Uses for-file
|
|
10
|
+
// --from-codeowners so the project is not built and the parser globs team
|
|
11
|
+
// files; the invalid bad_team.yml is skipped and an error is printed.
|
|
12
|
+
// With the fix: stderr contains "Error parsing team file:" and "missing field `github`".
|
|
13
|
+
// Without the fix (reverted): stderr only has generic "YAML serialization/deserialization failed".
|
|
14
|
+
#[test]
|
|
15
|
+
fn test_missing_github_team_in_team_file_is_reported_on_stderr() -> Result<(), Box<dyn Error>> {
|
|
16
|
+
run_codeowners(
|
|
17
|
+
"missing_github_team",
|
|
18
|
+
&["for-file", "--from-codeowners", "ruby/foo.rb"],
|
|
19
|
+
true, // command succeeds; invalid file is skipped
|
|
20
|
+
OutputStream::Stderr,
|
|
21
|
+
predicate::str::contains("Error parsing team file:").and(predicate::str::contains("missing field `github`")),
|
|
22
|
+
)
|
|
23
|
+
}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
use std::error::Error;
|
|
2
|
+
use std::path::Path;
|
|
3
|
+
|
|
4
|
+
mod common;
|
|
5
|
+
use common::{build_run_config, git_add_all_files, setup_fixture_repo};
|
|
6
|
+
|
|
7
|
+
#[test]
|
|
8
|
+
fn test_run_config_executable_path_overrides_config_file() -> Result<(), Box<dyn Error>> {
|
|
9
|
+
use codeowners::runner::validate;
|
|
10
|
+
|
|
11
|
+
let fixture_root = Path::new("tests/fixtures/custom_executable_name");
|
|
12
|
+
let temp_dir = setup_fixture_repo(fixture_root);
|
|
13
|
+
let project_path = temp_dir.path();
|
|
14
|
+
git_add_all_files(project_path);
|
|
15
|
+
|
|
16
|
+
// This fixture has executable_name: "bin/codeownership validate" in config
|
|
17
|
+
// But we'll override it with RunConfig.executable_name
|
|
18
|
+
|
|
19
|
+
let mut run_config = build_run_config(project_path, ".github/CODEOWNERS");
|
|
20
|
+
run_config.executable_name = Some("my-wrapper-tool validate".to_string());
|
|
21
|
+
|
|
22
|
+
let result = validate(&run_config, vec![]);
|
|
23
|
+
|
|
24
|
+
// Should use "my-wrapper-tool validate" from RunConfig, NOT "bin/codeownership validate" from config
|
|
25
|
+
assert!(!result.validation_errors.is_empty(), "Expected validation errors but got none");
|
|
26
|
+
let error_msg = result.validation_errors.join("\n");
|
|
27
|
+
assert!(
|
|
28
|
+
error_msg.contains("Run `my-wrapper-tool validate`"),
|
|
29
|
+
"Expected error to contain 'my-wrapper-tool validate' but got: {}",
|
|
30
|
+
error_msg
|
|
31
|
+
);
|
|
32
|
+
assert!(
|
|
33
|
+
!error_msg.contains("bin/codeownership"),
|
|
34
|
+
"Error should not contain config file's executable_name when overridden"
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
Ok(())
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
#[test]
|
|
41
|
+
fn test_run_config_without_executable_path_uses_config_file() -> Result<(), Box<dyn Error>> {
|
|
42
|
+
use codeowners::runner::validate;
|
|
43
|
+
|
|
44
|
+
let fixture_root = Path::new("tests/fixtures/custom_executable_name");
|
|
45
|
+
let temp_dir = setup_fixture_repo(fixture_root);
|
|
46
|
+
let project_path = temp_dir.path();
|
|
47
|
+
git_add_all_files(project_path);
|
|
48
|
+
|
|
49
|
+
// This fixture has executable_name: "bin/codeownership validate" in config
|
|
50
|
+
|
|
51
|
+
let mut run_config = build_run_config(project_path, ".github/CODEOWNERS");
|
|
52
|
+
run_config.executable_name = None; // Explicitly no override
|
|
53
|
+
|
|
54
|
+
let result = validate(&run_config, vec![]);
|
|
55
|
+
|
|
56
|
+
// Should use "bin/codeownership validate" from config file
|
|
57
|
+
assert!(!result.validation_errors.is_empty(), "Expected validation errors but got none");
|
|
58
|
+
let error_msg = result.validation_errors.join("\n");
|
|
59
|
+
assert!(
|
|
60
|
+
error_msg.contains("Run `bin/codeownership validate`"),
|
|
61
|
+
"Expected error to contain 'bin/codeownership validate' but got: {}",
|
|
62
|
+
error_msg
|
|
63
|
+
);
|
|
64
|
+
|
|
65
|
+
Ok(())
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
#[test]
|
|
69
|
+
fn test_run_config_executable_path_overrides_default() -> Result<(), Box<dyn Error>> {
|
|
70
|
+
use codeowners::runner::validate;
|
|
71
|
+
|
|
72
|
+
let fixture_root = Path::new("tests/fixtures/default_executable_name");
|
|
73
|
+
let temp_dir = setup_fixture_repo(fixture_root);
|
|
74
|
+
let project_path = temp_dir.path();
|
|
75
|
+
git_add_all_files(project_path);
|
|
76
|
+
|
|
77
|
+
// This fixture has NO executable_name in config (uses default "codeowners generate")
|
|
78
|
+
|
|
79
|
+
let mut run_config = build_run_config(project_path, ".github/CODEOWNERS");
|
|
80
|
+
run_config.executable_name = Some("custom-command generate".to_string());
|
|
81
|
+
|
|
82
|
+
let result = validate(&run_config, vec![]);
|
|
83
|
+
|
|
84
|
+
// Should use "custom-command generate" from RunConfig, NOT default "codeowners generate"
|
|
85
|
+
assert!(!result.validation_errors.is_empty(), "Expected validation errors but got none");
|
|
86
|
+
let error_msg = result.validation_errors.join("\n");
|
|
87
|
+
assert!(
|
|
88
|
+
error_msg.contains("Run `custom-command generate`"),
|
|
89
|
+
"Expected error to contain 'custom-command generate' but got: {}",
|
|
90
|
+
error_msg
|
|
91
|
+
);
|
|
92
|
+
assert!(
|
|
93
|
+
!error_msg.contains("codeowners generate"),
|
|
94
|
+
"Error should not contain default when overridden"
|
|
95
|
+
);
|
|
96
|
+
|
|
97
|
+
Ok(())
|
|
98
|
+
}
|
|
@@ -35,9 +35,10 @@ team_file_glob:
|
|
|
35
35
|
|
|
36
36
|
let run_config = RunConfig {
|
|
37
37
|
project_root: temp_dir.path().to_path_buf(),
|
|
38
|
-
codeowners_file_path: temp_dir.path().join(".github/CODEOWNERS").to_path_buf(),
|
|
38
|
+
codeowners_file_path: Some(temp_dir.path().join(".github/CODEOWNERS").to_path_buf()),
|
|
39
39
|
config_path: temp_dir.path().join("config/code_ownership.yml").to_path_buf(),
|
|
40
40
|
no_cache: true,
|
|
41
|
+
executable_name: None,
|
|
41
42
|
};
|
|
42
43
|
|
|
43
44
|
let file_owner = runner::file_owner_for_file(&run_config, "app/consumers/deep/nesting/nestdir/deep_file.rb")
|
|
@@ -60,9 +61,10 @@ fn test_teams_for_files_from_codeowners() {
|
|
|
60
61
|
];
|
|
61
62
|
let run_config = RunConfig {
|
|
62
63
|
project_root: project_root.to_path_buf(),
|
|
63
|
-
codeowners_file_path: project_root.join(".github/CODEOWNERS").to_path_buf(),
|
|
64
|
+
codeowners_file_path: Some(project_root.join(".github/CODEOWNERS").to_path_buf()),
|
|
64
65
|
config_path: project_root.join("config/code_ownership.yml").to_path_buf(),
|
|
65
66
|
no_cache: true,
|
|
67
|
+
executable_name: None,
|
|
66
68
|
};
|
|
67
69
|
let teams =
|
|
68
70
|
runner::teams_for_files_from_codeowners(&run_config, &file_paths.iter().map(|s| s.to_string()).collect::<Vec<String>>()).unwrap();
|
|
@@ -126,9 +128,10 @@ javascript_package_paths:
|
|
|
126
128
|
|
|
127
129
|
let rc = RunConfig {
|
|
128
130
|
project_root: td.path().to_path_buf(),
|
|
129
|
-
codeowners_file_path: td.path().join(".github/CODEOWNERS"),
|
|
131
|
+
codeowners_file_path: Some(td.path().join(".github/CODEOWNERS")),
|
|
130
132
|
config_path: td.path().join("config/code_ownership.yml"),
|
|
131
133
|
no_cache: true,
|
|
134
|
+
executable_name: None,
|
|
132
135
|
};
|
|
133
136
|
|
|
134
137
|
// Ensure CODEOWNERS file matches generator output to avoid out-of-date errors
|
|
@@ -167,9 +170,10 @@ javascript_package_paths:
|
|
|
167
170
|
|
|
168
171
|
let rc = RunConfig {
|
|
169
172
|
project_root: td.path().to_path_buf(),
|
|
170
|
-
codeowners_file_path: td.path().join(".github/CODEOWNERS"),
|
|
173
|
+
codeowners_file_path: Some(td.path().join(".github/CODEOWNERS")),
|
|
171
174
|
config_path: td.path().join("config/code_ownership.yml"),
|
|
172
175
|
no_cache: true,
|
|
176
|
+
executable_name: None,
|
|
173
177
|
};
|
|
174
178
|
|
|
175
179
|
let gv = runner::generate_and_validate(&rc, vec![], true);
|
|
@@ -241,7 +241,7 @@ fn test_for_file_same_team_multiple_ownerships() -> Result<(), Box<dyn Error>> {
|
|
|
241
241
|
Team YML: config/teams/payroll.yml
|
|
242
242
|
Description:
|
|
243
243
|
- Owner annotation at the top of the file
|
|
244
|
-
- Owner defined in `javascript/packages/PayrollFlow/package.json` with
|
|
244
|
+
- Owner defined in `javascript/packages/PayrollFlow/package.json` with implicitly owned glob: `javascript/packages/PayrollFlow/**/**`
|
|
245
245
|
"}));
|
|
246
246
|
Ok(())
|
|
247
247
|
}
|
|
@@ -262,7 +262,7 @@ fn test_fast_for_file_same_team_multiple_ownerships() -> Result<(), Box<dyn Erro
|
|
|
262
262
|
Team YML: config/teams/payroll.yml
|
|
263
263
|
Description:
|
|
264
264
|
- Owner annotation at the top of the file
|
|
265
|
-
- Owner defined in `javascript/packages/PayrollFlow/package.json` with
|
|
265
|
+
- Owner defined in `javascript/packages/PayrollFlow/package.json` with implicitly owned glob: `javascript/packages/PayrollFlow/**/**`
|
|
266
266
|
"}));
|
|
267
267
|
Ok(())
|
|
268
268
|
}
|
|
@@ -283,7 +283,7 @@ fn test_for_file_with_2_ownerships() -> Result<(), Box<dyn Error>> {
|
|
|
283
283
|
Team YML: config/teams/payroll.yml
|
|
284
284
|
Description:
|
|
285
285
|
- Owner annotation at the top of the file
|
|
286
|
-
- Owner defined in `javascript/packages/PayrollFlow/package.json` with
|
|
286
|
+
- Owner defined in `javascript/packages/PayrollFlow/package.json` with implicitly owned glob: `javascript/packages/PayrollFlow/**/**`
|
|
287
287
|
"}));
|
|
288
288
|
|
|
289
289
|
Ok(())
|