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

(feat) internal/civisibility: add support for file environmental data #3319

Merged
merged 4 commits into from
Mar 27, 2025

Conversation

tonyredondo
Copy link
Member

@tonyredondo tonyredondo commented Mar 20, 2025

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:

  • Added a new environment variable CIVisibilityEnvironmentDataFilePath to store the path to the environmental data file (internal/civisibility/constants/env.go).
  • Implemented functions to read and apply environmental data from a file, including getEnvironmentalData, applyEnvironmentalDataIfRequired, and writeEnvironmentalDataToFile (internal/civisibility/utils/file_environmental_data.go).
  • Updated the createCITagsMap function to apply environmental data if available (internal/civisibility/utils/environmentTags.go).

Codeowners File Handling:

  • Refactored the GetCodeOwners function to use a new helper function parseCodeOwners 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

  • Changed code has unit tests for its functionality at or near 100% coverage.
  • System-Tests covering this feature have been added and enabled with the va.b.c-dev version tag.
  • There is a benchmark for any new code, or changes to existing code.
  • If this interacts with the agent in a new way, a system test has been added.
  • Add an appropriate team label so this PR gets put in the right place for the release notes.
  • Non-trivial go.mod changes, e.g. adding new modules, are reviewed by @DataDog/dd-trace-go-guild.
  • For internal contributors, a matching PR should be created to the v2-dev branch and reviewed by @DataDog/apm-go.

Unsure? Have a question? Request a review!

@datadog-datadog-prod-us1
Copy link

datadog-datadog-prod-us1 bot commented Mar 20, 2025

Datadog Report

Branch report: tony/add-support-for-file-environmental-data
Commit report: 100cc09
Test service: dd-trace-go

✅ 0 Failed, 5487 Passed, 72 Skipped, 11m 36.42s Total Time

@tonyredondo tonyredondo self-assigned this Mar 20, 2025
@pr-commenter
Copy link

pr-commenter bot commented Mar 20, 2025

Benchmarks

Benchmark execution time: 2025-03-27 10:23:37

Comparing candidate commit 447536c in PR branch tony/add-support-for-file-environmental-data with baseline commit ba03925 in branch main.

Found 1 performance improvements and 2 performance regressions! Performance is the same for 57 metrics, 2 unstable metrics.

scenario:BenchmarkSetTagMetric-24

  • 🟥 execution_time [+5.143ns; +8.017ns] or [+4.347%; +6.777%]

scenario:BenchmarkSetTagString-24

  • 🟥 execution_time [+6.127ns; +9.153ns] or [+5.362%; +8.010%]

scenario:BenchmarkStartRequestSpan-24

  • 🟩 execution_time [-33.974ns; -32.706ns] or [-7.006%; -6.745%]

@tonyredondo tonyredondo force-pushed the tony/add-support-for-file-environmental-data branch from a839de2 to 0725df8 Compare March 20, 2025 11:52
@tonyredondo tonyredondo marked this pull request as ready for review March 20, 2025 12:11
@tonyredondo tonyredondo requested review from a team as code owners March 20, 2025 12:11
@tonyredondo tonyredondo force-pushed the tony/add-support-for-file-environmental-data branch from 0725df8 to 154c559 Compare March 22, 2025 12:13
@tonyredondo tonyredondo force-pushed the tony/add-support-for-file-environmental-data branch from 24317f7 to 097abf8 Compare March 26, 2025 09:38
@tonyredondo tonyredondo enabled auto-merge (squash) March 27, 2025 09:46
@tonyredondo tonyredondo merged commit 1be9aea into main Mar 27, 2025
178 checks passed
@tonyredondo tonyredondo deleted the tony/add-support-for-file-environmental-data branch March 27, 2025 10:42
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants