(feat) internal/civisibility: add support for file environmental data #3319
+858
−9
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What does this PR do?
V2: (fix) internal/civisibility: add support for file environmental data - v2
This pull request introduces significant changes to handle environmental data more effectively in the CI visibility module. The changes include adding a new environment variable, refactoring the code to improve the handling of
CODEOWNERS
files, and implementing functions to read, apply, and write environmental data.Environment Data Handling:
CIVisibilityEnvironmentDataFilePath
to store the path to the environmental data file (internal/civisibility/constants/env.go
).getEnvironmentalData
,applyEnvironmentalDataIfRequired
, andwriteEnvironmentalDataToFile
(internal/civisibility/utils/file_environmental_data.go
).createCITagsMap
function to apply environmental data if available (internal/civisibility/utils/environmentTags.go
).Codeowners File Handling:
GetCodeOwners
function to use a new helper functionparseCodeOwners
for better readability and error handling (internal/civisibility/utils/codeowners.go
).These changes enhance the CI visibility module by making it easier to manage and apply environmental data, improving the robustness and maintainability of the code
Motivation
This feature helps on those scenarios where the tests are built in a host machine and then executed in an isolate environment. With this feature we can store the environmental data at build time, and then load it at run time.
In this file we plan to store the data related to the CI provider and Git info required by the test optimization product.
Reviewer's Checklist
v2-dev
branch and reviewed by @DataDog/apm-go.Unsure? Have a question? Request a review!