-
Notifications
You must be signed in to change notification settings - Fork 192
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
Use pre-commit run prettier
if prettier
is not available
#1983
Conversation
Codecov Report
@@ Coverage Diff @@
## dev #1983 +/- ##
==========================================
+ Coverage 67.41% 67.51% +0.09%
==========================================
Files 42 42
Lines 5463 5467 +4
==========================================
+ Hits 3683 3691 +8
+ Misses 1780 1776 -4
Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. |
So, I tried this out as follows in the module repo, with the tools repo installed from your fork/branch. Is this what you expect @fabianegli ? I'm guessing the first commit shouldn't fail that way? Test steps:
|
@pinin4fjords Thanks again for testing this PR. For anyone wanting to tag along: Setting everything up:
Creating a new module:
press "n" for the biocontainer question and use the defaults for everything else.
After #2021 is merged, the git diff should be empty. |
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.
Could we just add a nf-core lint setup
or just instruct users to run
pre-commit install
And include pre-commit as a dependency in tools?
nf_core/lint_utils.py
Outdated
def _run_prettier_on_file(file): | ||
"""Run natively installed Prettier on a file.""" | ||
|
||
try: | ||
subprocess.run( | ||
["prettier", "--write", file], | ||
stdout=subprocess.DEVNULL, | ||
stderr=subprocess.DEVNULL, | ||
check=False, | ||
capture_output=True, | ||
check=True, | ||
) | ||
except subprocess.CalledProcessError as e: | ||
if ": SyntaxError: " in e.stderr.decode(): | ||
raise ValueError(f"Can't format {file} because it has a synthax error.\n{e.stderr.decode()}") from e | ||
raise ValueError( | ||
"There was an error running the prettier pre-commit hook.\n" | ||
f"STDOUT: {e.stdout.decode()}\nSTDERR: {e.stderr.decode()}" | ||
) from e |
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'd vote we either go all in on pre-commit
for nf-core tools or not.
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.
And include pre-commit as a dependency in tools?
This PR makes pre-commit a dependency. Installing the hooks is not necessary, they can be run directly. Installing them with pre-commit install
just makes them run before any commit in the repo. So install is not (just) installing the tools but setting a git repo up to use them. pre-commit run
will also install the hooks but not change any settings in any git repo. The beauty of pre-commit is that it takes care of everything based on the configuration file and because we have one we can just use it.
The way it is set up means the user doesn't need to handle any installation manually and neither is there a need for a separate nf-core lint setup
command.
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.
Okay, I'm following now. Still wondering, since it'll be installed, why allow the system prettier
install? I get it's probably faster, less stuff installed, but more code for us to maintain.
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 am all for only using prettier via the pre-commit hook mechanism. The global Prettier would make the first invocation a bit quicker, because pre-commit has to pull the hook from the web the first time it runs. I also have some questions about the configuration for when prettier is invoked from a global install, because it might not see the same configs as the one from the pre-commit hooks. I'd have to look at this, too.
One more point for only using pre-commit prettier is that the code - both n production and testing - would become much simpler.
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 am tempted to actually promote running pre-commit install by default. It would make the developer experience more platform independent, but it also installs pre-commit hooks in all repos nf-core is used in and this may or may not be desirable depending on the project.
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.
because pre-commit has to pull the hook from the web the first time it runs.
And this also means internet access is necessary for the first time prettier is run. If a developer doesn't have internet access but prettier is installed on the machine it would help to keep the current setup, although it is more complex. (hitherto I remain ignorant about the issue of the configuration for Prettier native)
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'd like to move the discussion about the use of pre-commit install out of this PR because I see it as a separate issue that does not decrease the usefulness of this PR, but considerably complicates it and would drag the merge of this PR unnecessarily.
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.
How/where does running pre-commit prettier
get it's config? Although the primary use-case for tools is working with the public nf-core
repos I am mindful of the fact that people do use them internally (selfish bias here too as I do) and wonder whether there are cases where running prettier
(or using some fixed config) is undesirable?
If pre-commit prettier
draws its config from the repo/global config files in the same way as running manually installed prettier does then this is probably less of an issue
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.
The hooks take the configuration in the repository where they are run into account.
nf_core/lint_utils.py
Outdated
subprocess.run( | ||
["pre-commit", "run", "--config", nf_core_pre_commit_config, "prettier", "--files", file], | ||
capture_output=True, | ||
check=True, | ||
) |
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.
Just wondering if we can import pre-commit the package and call this manually? Or is using it as a subprocess more transparent.
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 manual and the subprocess version serve different purposes. The automated one should make sure all autogenerated file changes are lint-compliant and the manual invocations can help after manually changing files plus installing the pre-commit hooks will protect the git revision history from content that doesn't pass linting.
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.
Sorry, I answered the wrong question. The real one I don't know. Well, I kind of know. It's not the intended use of pre-commit. Not impossible, but a hack.
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.
If you want to know why I classify the alternative as a "hack", compare the complexity of the parameters in the run
function wit the much simpler command line invocation.
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.
Sidenote: running a command in subprocess adds very little overhead (about 0.04 seconds on a 10 year old machine) and there's no state or computation that we already have when we invoke it that we can share with prettier to make it run faster anyway. I would say we can drop this line of inquiry.
Note to Slack about the plan to drop support for running non-pre-commit hook Prettier installations. |
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.
LGTM 👍🏻
This is a POC for a proposal in #1972 and should be discussed before being merged.
This PR is introduces the ability to use Prettier on systems that don't have it installed already - via the use of the prettier pre-commit hook available from the nf-core pre-commit configuration.
Of specific interest for discussion is the move of pre-commit from being a development dependency to being a production dependency.
I was not able to test this PR thoroughly - so it would be nice if someone who is more experienced with pipeline/module developers to experiment.
It would probably be easy from here on out to run the pre commit hooks by default after each file mutation that the tools make. This could then also run all or a selection of the other hooks in the config.
This contains the changes currently in #1974
ToDo
pre-commit
Prettier installationsNotes:
PR checklist
CHANGELOG.md
is updateddocs
is updated