- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.1k
Remove pvgis_tmy outputformat='basic' #2416
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 pvgis_tmy outputformat='basic' #2416
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think there is no technical barrier to deprecating outputformat='basic' for a while before removing it altogether.  However, I bet basic is hardly used, so for the sake of expediency and not taxing @AdamRJensen's patience, I am okay with no deprecation period here, although I grumble nonetheless.
I did not do a thorough review, but these changes seem okay to me (assuming nobody objects to removing basic in the first place).  A couple small notes below.
| 
 I am planning other breaking changes (consistent output of (data,meta)) which cannot have a deprecation period. So since these functions will be affected by a breaking change in the next release, it's better to include this breaking change too; which would minimize the number of times users would potentially need to update their code. @mikofski It would be great if you review this since you're the original author! | 
| It would be nice to get this merged soon, so I can move on to the next changes of the PVGIS functions (standardizing the output of  @mikofski it would be great if you could take a brief look! | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the "nicer" error message @kandersolar requested for get_pvgis_tmy() was accidently added to read_pvgis_hourly() which never accepted 'basic' as an input, so get_pvgis_tmy() still doesn't raise this "nicer" message. This reveals that read_pvgis_hourly() didn't have a test condition (until now) to handle if outputformat was neither 'json' nor 'csv'. Removal of the "basic" test data removed a test if the file extension was neither 'json', 'csv', nor 'epw'
| def test_read_pvgis_tmy_basic(expected, meta_expected): | ||
| fn = TESTS_DATA_DIR / 'tmy_45.000_8.000_2005_2023.txt' | ||
| # XXX: can't infer outputformat from file extensions for basic | ||
| with pytest.raises(ValueError, match="pvgis format 'txt' was unknown"): | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
there are not tests now for raising an exception if either the file extension or pvgis_format was not 'json' or 'csv'. Don't need the basic test file, can create a named temp file instead.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is now a dedicated test that checks if an error is raised when a filename with a non-recognized file format is passed.
docs/sphinx/source/referencefor API changes.docs/sphinx/source/whatsnewfor all changes. Includes link to the GitHub Issue with:issue:`num`or this Pull Request with:pull:`num`. Includes contributor name and/or GitHub username (link with:ghuser:`user`).remote-data) and Milestone are assigned to the Pull Request and linked Issue.PVGIS offers multiple output formats. For hourly data the file formats ['csv', 'json', 'basic'] are available, whereas for TMY data file format of ['csv', 'json', 'epw', 'basic'] are available.
I suggest that we drop support for the
'basic'output format as there is no point to it; the file type is the same as the csv option but without any header or metadata. For this reason, the file option is also not available on the pvgis web interface and is already not supported by pvlib's pvgis_hourly functions.The motivation is to reduce the maintenance burden, as dropping support for this file format reduces the code complexity significantly without any drawbacks for users. I'm currently planning more changes to the pvgis functions, but would like this change to be merged first. The planned changes mostly involve changing the outputs to be (data,meta) to be consistent with the rest of the iotools.