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

Remove JSON examples from artifacts #450

Open
wants to merge 9 commits into
base: dev
Choose a base branch
from

Conversation

YaSuenag
Copy link
Member

Pull Request

#440

Summary

Remove data source and location source JSONs from artifacts.

These JSONs are no longer provided from both CLI and WebAPI includes container image, but we can use them of course if we need because JSONs are still kept in the repo.

Changes

Essense of this PR is following:

  • src/CarbonAware.DataSources/CarbonAware.DataSources.Json/src/CarbonAware.DataSources.Json.csproj
    • Remove JSONs in data-sources/ from ItemGroup, and data-sources/json would be created in publish directory.
  • src/CarbonAware.LocationSources/src/CarbonAware.LocationSources.csproj
    • Remove JSONs in location-sources/ from ItemGroup, and location-sources/json would be created in publish directory.
  • src/CarbonAware.DataSources/CarbonAware.DataSources.Json/src/Configuration/JsonDataSourceConfiguration.cs
    • test-data-azure-emissions.json is no longer set by default.
  • src/CarbonAware.WebApi/src/Dockerfile
    • WebAPI container is no longer started without any configuration, so set JSON data source before dotnet tool run for generating OpenAPI document.
  • src/CarbonAware.WebApi/src/appsettings.json
    • Remove data source configuration.
  • src/GSF.CarbonAware/src/GSF.CarbonAware.csproj
    • Remove both data-sources and location-sources.
  • src/GSF.CarbonAware/src/GSF.CarbonAware.targets
    • Remove both data-sources and location-sources, but they would be created into publish directory.

This PR has other changes, but they are for test cases because they depends JSON data source and location source.

Note that I commented out test case for ElectricityMapsFree in both src/CarbonAware.WebApi/test/integrationTests/CarbonAwareControllerTests.cs and src/CarbonAware.WebApi/test/integrationTests/LocationsControllerTests.cs because IntegrationTestingBase.cs does not have configuration for ElectricityMapsFree. I will fix it after this PR.

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?

This PR breaks current behavior. CASDK is no longer refer test-data-azure-emissions.json for data source and azure-regions.json for location source. CASDK requires the user to configure data source at least.

Signed-off-by: Yasumasa Suenaga <[email protected]>
Copy link
Contributor

This a stale pull request. Please review, update or/and close as necessary.

@YaSuenag
Copy link
Member Author

This PR conflicts current dev branch. I will fix after #555.

YaSuenag and others added 5 commits December 11, 2024 14:07
Signed-off-by: Yasumasa Suenaga <[email protected]>
Signed-off-by: Yasumasa Suenaga <[email protected]>
Signed-off-by: Yasumasa Suenaga <[email protected]>
@@ -15,7 +15,7 @@ namespace CarbonAware.WepApi.IntegrationTests;
[TestFixture(DataSourceType.JSON)]
[TestFixture(DataSourceType.WattTime)]
[TestFixture(DataSourceType.ElectricityMaps)]
[TestFixture(DataSourceType.ElectricityMapsFree)]
//[TestFixture(DataSourceType.ElectricityMapsFree)] // TODO: need to implement data source into IntegrationTestingBase.cs
Copy link
Collaborator

Choose a reason for hiding this comment

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

Do we need to document better why this is being ignored for this PR please?

Copy link
Member Author

Choose a reason for hiding this comment

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

I updated my Visual Studio Community 2022 to version 17.12.3 , then all tests are passed without commented-out.
スクリーンショット 2025-01-07 204611
This screenshot shows EMFree datasource tests in both CarbonAwareControllerTests.cs and LocationsControllerTests.cs have been skipped. I wonder why they were skipped, but it might be the issue in VS (or test facilities in dotnet) because the issue has gone in the latest VS.

Can someone evaluate on your environment without // ? I will remove // if it works on other environment(s).

Copy link
Member Author

Choose a reason for hiding this comment

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

The tests failed again!

The root cause is that the test for ElectricityMapsFree would load JsonDataSource.

As I pointed before, ElectricityMapsFree has not been handled at IntegrationTestingBase.
WebAPI testcase would use src/CarbonAware.WebApi/src/appsettings.json which makes dependency to JsonDataSource. Thus tests for ElectricityMapsFree works without errors - it means ElectricityMapsFree tests are not valid because it uses JsonDataSource.

@danuw @vaughanknight
Should we fix the tests for ElectricityMapsFree before this PR?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: In Progress
Development

Successfully merging this pull request may close these issues.

2 participants