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

Implement Data Source Registration per ADR-0006 #366

Open
wants to merge 1 commit into
base: dev
Choose a base branch
from

Conversation

bderusha
Copy link
Contributor

@bderusha bderusha commented Jun 26, 2023

Pull Request

Issue Number: #348

Summary

Loads data sources declared in the .csproj file and configured using the standard configuration dynamically rather than through the hardcoded registration project.

There are many files with tiny, ancillary changes necessary to plumb everything together this way. However the main changes are to the data source files:

And the Configuration class
And the ServiceCollectionExtension

Changes

  • Dynamic loading support
  • All data sources updated to match the interface
  • Updated documentation

Checklist

  • Local Tests Passing?
  • CICD and Pipeline Tests Passing?
  • Added any new Tests?
  • Documentation Updates Made?
  • Are there any API Changes? If yes, please describe below.
  • This is not a breaking change. If it is, please describe it below.

Are there API Changes?

No

Is this a breaking change?

Yes, projects using the SDK Library now must declare data source packages explicitly.

Anything else?

Other comments, collaborators, etc.

Please follow
GitHub's suggested syntax
to link Pull Requests to Issues via keywords

This PR Closes #348

@bderusha bderusha requested review from danuw and Willmish June 26, 2023 14:14
@bderusha bderusha changed the title Feat/dynamic data sources Implement Data Source Registration per ADR-0006 Jun 26, 2023
@bderusha bderusha force-pushed the feat/dynamic-data-sources branch 4 times, most recently from 68e6f35 to fbbd9af Compare June 29, 2023 13:47
@codecov-commenter
Copy link

codecov-commenter commented Jun 29, 2023

Codecov Report

Merging #366 (ac5aae6) into dev (ad44005) will increase coverage by 5.35%.
Report is 7 commits behind head on dev.
The diff coverage is 65.78%.

❗ Your organization is not using the GitHub App Integration. As a result you may experience degraded service beginning May 15th. Please install the GitHub App Integration for your organization. Read more.

Impacted file tree graph

@@            Coverage Diff             @@
##              dev     #366      +/-   ##
==========================================
+ Coverage   74.21%   79.56%   +5.34%     
==========================================
  Files          77       75       -2     
  Lines        2637     2701      +64     
  Branches      266      268       +2     
==========================================
+ Hits         1957     2149     +192     
+ Misses        598      457     -141     
- Partials       82       95      +13     
Files Changed Coverage Δ
src/CarbonAware.WebApi/src/Program.cs 80.26% <ø> (ø)
src/CarbonAware/src/Interfaces/IDataSource.cs 0.00% <0.00%> (ø)
...psFree/mock/ElectricityMapsFreeDataSourceMocker.cs 95.12% <33.33%> (ø)
...s.ElectricityMaps/src/ElectricityMapsDataSource.cs 61.31% <50.00%> (-2.77%) ⬇️
...icityMapsFree/src/ElectricityMapsFreeDataSource.cs 63.63% <50.00%> (+63.63%) ⬆️
...are.DataSources.WattTime/src/WattTimeDataSource.cs 88.53% <74.28%> (-4.09%) ⬇️
...ware/src/Configuration/DataSourcesConfiguration.cs 89.65% <75.00%> (-10.35%) ⬇️
...ware/src/Extensions/ServiceCollectionExtensions.cs 76.19% <76.19%> (ø)
...CarbonAware.DataSources.Json/src/JsonDataSource.cs 80.76% <84.61%> (+0.76%) ⬆️
...onfiguration/DataSourcesConfigurationExtensions.cs 83.33% <100.00%> (ø)
... and 1 more

... and 6 files with indirect coverage changes

@bderusha bderusha force-pushed the feat/dynamic-data-sources branch 5 times, most recently from 7065dce to c3d13a3 Compare June 30, 2023 16:54
@bderusha bderusha force-pushed the feat/dynamic-data-sources branch 16 times, most recently from 726c716 to c47f1bc Compare September 5, 2023 20:29
@bderusha bderusha force-pushed the feat/dynamic-data-sources branch from c47f1bc to 408fcb1 Compare September 11, 2023 15:49
@danuw
Copy link
Collaborator

danuw commented May 14, 2024

@bderusha , I can see there are some outstanding conflicts here - are you able to help update and see how we can progress please?

@bderusha
Copy link
Contributor Author

@danuw Is this PR something the community is ready to review and merge?

If yes, and we are going to prioritize this PR, I can prioritize making the required updates (both to current conflicts and any feedback).

@NAMRATA-WOKE
Copy link

@danuw is there an update here that you'd like to share with the rest of the community?

@danuw danuw added this to the Release 1.6 milestone Aug 27, 2024
@danuw danuw added the v1.6 label Aug 27, 2024
@danuw danuw added v1.7 and removed v1.6 labels Sep 10, 2024
@danuw danuw modified the milestones: Release 1.6, Release 1.7 Oct 8, 2024
@danuw danuw added v1.8 and removed v1.7 labels Jan 7, 2025
@danuw danuw removed this from the Release 1.7 milestone Jan 7, 2025
@danuw danuw requested a review from Copilot January 14, 2025 08:18

Choose a reason for hiding this comment

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

Copilot reviewed 58 out of 73 changed files in this pull request and generated no comments.

Files not reviewed (15)
  • .vscode/launch.json: Language not supported
  • samples/azure/azure-function/Dockerfile: Language not supported
  • samples/azure/azure-function/function.csproj: Language not supported
  • samples/azure/azure-function/host.json: Language not supported
  • scripts/package/add_packages.ps1: Language not supported
  • scripts/package/create_packages.ps1: Language not supported
  • src/CarbonAware.CLI/src/CarbonAware.CLI.csproj: Language not supported
  • src/CarbonAware.CLI/test/integrationTests/CarbonAware.CLI.IntegrationTests.csproj: Language not supported
  • src/CarbonAware.DataSources/CarbonAware.DataSources.ElectricityMaps/mock/CarbonAware.DataSources.ElectricityMaps.Mocks.csproj: Language not supported
  • src/CarbonAware.DataSources/CarbonAware.DataSources.ElectricityMaps/src/CarbonAware.DataSources.ElectricityMaps.csproj: Language not supported
  • src/CarbonAware.DataSources/CarbonAware.DataSources.ElectricityMaps/src/CarbonAware.DataSources.ElectricityMaps.targets: Language not supported
  • src/CarbonAware.CLI/test/integrationTests/Commands/Emissions/EmissionsCommandTests.cs: Evaluated as low risk
  • src/CarbonAware.CLI/test/integrationTests/Commands/Location/LocationCommandTests.cs: Evaluated as low risk
  • src/CarbonAware.CLI/test/integrationTests/Commands/EmissionsForecasts/EmissionsForecastsCommandTests.cs: Evaluated as low risk
  • src/CarbonAware.CLI/test/integrationTests/IntegrationTestingBase.cs: Evaluated as low risk
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Ready for Review PR Ready for review with the GSF team for merge v1.8
Projects
Status: In Progress
Development

Successfully merging this pull request may close these issues.

[Feature Contribution]: Implement Data Source Registration per ADR-0006
6 participants