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

yaml literals #70

Merged
merged 26 commits into from
Dec 3, 2022
Merged

yaml literals #70

merged 26 commits into from
Dec 3, 2022

Conversation

fkuep
Copy link
Contributor

@fkuep fkuep commented Nov 25, 2022

#69

src/scriv/literals.py Outdated Show resolved Hide resolved
src/scriv/literals.py Outdated Show resolved Hide resolved
@nedbat
Copy link
Owner

nedbat commented Nov 28, 2022

Thanks! The quality failure is because of missing blank lines:

--- src/scriv/literals.py	2022-11-28 11:30:03.217489 +0000
+++ src/scriv/literals.py	2022-11-28 11:31:41.120974 +0000
@@ -13,10 +13,11 @@

 try:
     import yaml
 except ImportError:  # pragma: no cover
     yaml = None  # type: ignore
+

 def find_literal(file_name: str, literal_name: str) -> Optional[str]:
     """
     Look inside a file for a literal value, and return it.

@@ -111,10 +112,11 @@

     if isinstance(current_object, str):
         return current_object
     return None

+
 def find_yaml_value(data: MutableMapping[str, Any], name: str) -> Optional[str]:
     """
     Use a period-separated name to traverse a dictionary.

     Only string values are supported.

I've improved the check on main so that it would be more evident in the future.

Can you write some tests? The toml support has ones you can use as a model. Also, a scriv entry? :)

fkuep and others added 3 commits November 29, 2022 08:14
safe_load will take an open file

Co-authored-by: Ned Batchelder <ned@nedbatchelder.com>
@fkuep
Copy link
Contributor Author

fkuep commented Nov 29, 2022

Thanks! The quality failure is because of missing blank lines:

One is gone with the superfluous function, one blank line inserted.

I've improved the check on main so that it would be more evident in the future.

Thanks for making those easier to understand. I gave it a try here with little experiance and a simple text editor, so the likelihood of triggering the quality bots is high.

Can you write some tests? The toml support has ones you can use as a model.

I feared You'd say that 😄 I will try right now.

Also, a scriv entry? :)

How could I forget?

@fkuep
Copy link
Contributor Author

fkuep commented Nov 29, 2022

@nedbat
Copy link
Owner

nedbat commented Nov 29, 2022

You need to add types-yaml to requirements/quality.in, then run make upgrade

@fkuep
Copy link
Contributor Author

fkuep commented Nov 29, 2022

You need to add types-yaml to requirements/quality.in, then run make upgrade
Thank You for the hint Ned,
if You don't me asking in baby-steps , now I have:
https://github.com/fkuep/scriv/actions/runs/3576852541/jobs/6015152869#step:5:190
Is that because I was running make upgrade on python 3.9 ?

@nedbat
Copy link
Owner

nedbat commented Nov 29, 2022

It looks like you ran make upgrade on Python 3.10, and yes, that's why the installation is failing. You need to run it on the lowest supported version, which is 3.7. If you can't, I can make a PR into this one later.

@fkuep
Copy link
Contributor Author

fkuep commented Nov 29, 2022

run it on the lowest supported version, which is 3.7. If you can't, I can make a PR into this one later.

I will try

@fkuep
Copy link
Contributor Author

fkuep commented Nov 29, 2022

I will pick that up tomorrow (it was a long day) .
Is it ok that the matrix- tests are failing on my fork ?
It would be great to know , if I could start trying to write a test tomorrow.
Thank You very much for Your patience Ned.
Is it ok to ask You so much still ?

@nedbat
Copy link
Owner

nedbat commented Nov 29, 2022

Sorry about the tests on your fork. I've fixed that test on master. Get that code, and your tests should pass.

Ask me anything you need, I really appreciate you putting in the work.

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

Good morning Ned,

tests on your fork. I've fixed that test on master. Get that code, and your tests should pass.

I have added 5a9c278

The matrix test still don't run.
Do I understand it correctly in "linters etc" the tests/test_literals.py test is not run yet ?

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

I can now fail on purpose:
https://github.com/fkuep/scriv/actions/runs/3584124068/jobs/6030399247#step:8:54

and also run successful tests:
https://github.com/fkuep/scriv/actions/runs/3584100481/jobs/6030339738#step:8:37

I tried (modeled after toml) testing for installation of extra yaml , but that I don't understand yet.

I will now have a look at tests/test_gitinfo.py

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

I beleive Your code assumes a github repo should end in .git
https://github.com/nedbat/scriv/blob/main/src/scriv/gitinfo.py#L90

While my url line is:

origin https://github.com/fkuep/scriv (fetch)

From the test You even say that, but then gitinfo.py does not reflect that.
https://github.com/fkuep/scriv/actions/runs/3584281900/jobs/6030754148#step:8:97

did I miss a patch ?

@nedbat
Copy link
Owner

nedbat commented Nov 30, 2022

Your pull request is helping me find all sort of problems to fix! Merge master again to fix the test_gitinfo problem, and removing your debug prints will solve one of the others. I haven't looked at the yaml failure.

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

Merge master again

on my way..

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

YESS!!!

image

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

I am off the keyboard for 15 mins. ... celebratory coffee

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

@nedbat
Copy link
Owner

nedbat commented Nov 30, 2022

Looks like it's just a mismatch in the case of "yaml" between the message and the regex matching the message:

    def test_find_yaml_literal_fail_if_unavailable(monkeypatch):
        monkeypatch.setattr(scriv.literals, "yaml", None)
>       with pytest.raises(Exception, match="Can't read .+ without YAML support"):
E       AssertionError: Regex pattern did not match.
E        Regex: "Can't read .+ without YAML support"
E        Input: "Can't read 'foo.yml' without yaml support. Install with [yaml] extra"

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

@fkuep
Copy link
Contributor Author

fkuep commented Nov 30, 2022

Ned,
that might be the last thing I can think of:
While I was hunting this "yaml support" issue, I put pyyaml in test.in

(scriv_venv) root@buster:~/scriv/scriv# grep -ni yaml requirements/*.in
requirements/quality.in:19:types-pyyaml
requirements/test.in:11:pyyaml
(scriv_venv) root@buster:~/scriv/scriv# 

Should I remove that or put in quality.in ?
Any cleanup ? Docs addition ok ?

@nedbat
Copy link
Owner

nedbat commented Dec 1, 2022

I think you were right to put pyyaml into test.in

I've fixed the badge creation on master, if you merge one more time, your Coverage check will pass

The docs look fine. I think I will take an editing pass over that whole section, since the first sentence mentions "variables", which is a holdover from the only-.py days.

I think this might be ready to go!

@fkuep
Copy link
Contributor Author

fkuep commented Dec 1, 2022

I've fixed the badge creation on master, if you merge one more time, your Coverage check will pass
running now.

I don't mind though.

I think this might be ready to go!

GREAT!

Mind You - I have written an eMail to You with three little beginner Questions I have.
Specificially coined in the context of scriv, so it does not get too abstract.
I think You would need less than 15 minutes, to make my curiosity happy!

If You like some other way of doing that chat vid-conference, whatever... I am happy too.

Cheers, Florian!

@fkuep
Copy link
Contributor Author

fkuep commented Dec 1, 2022

Coverage badge run succeeds!

@nedbat nedbat merged commit 65f7e96 into nedbat:main Dec 3, 2022
@nedbat
Copy link
Owner

nedbat commented Dec 3, 2022

Thanks!!

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