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

Unify commands and centralize logging #703

Merged
merged 16 commits into from
Sep 9, 2021
Merged

Conversation

0x2b3bfa0
Copy link
Member

@0x2b3bfa0 0x2b3bfa0 commented Aug 31, 2021

Changes

  • Fixes Better logging #22 by using winston as a logging library instead of manually monkey–patching and aliasing console.log and console.error to custom identifiers. Running commands on a TTY will print colorized, human readable logs; other scenarios (like piping) will produce machine-readable JSONL like in the gh command-line tool. Now there is a single exception handler common for all the command-line interface, eliminating all the duplicate code and delegating the exception formatting on the logging library.

  • Fixes Unify commands under a single entry point #699 by moving all the separate commands until a single command named cml and setting up aliases for backwards comaptibility.

  • Partially fixes (this is not a closing keyword) Add documentation links and helpful descriptions to error messages #606, but needs additional work from the documentation side so we can link it from the error messages.

  • Introduces automatic environment variable processing with yargs.env so cml --long-option=value is equivalent to CML_LONG_OPTION=value cml without any maintenance overhead.

  • Introduces plugin support, allowing executables on the PATH to be called as subcommands from the new cml command; e.g. calling cml something will try to find and execute cml-something if it's in your path. As in gh extensions, external commands can't override internal ones under any circumstance.

  • Removes the default CMD on our container images (was set to cml-runner for no apparent reason) and sets a smart ENTRYPOINT that interprets unknown commands as cml commands. It didn't make too much sense to favor a tool over the rest and have seven similar ways of checking the installed CML version.

  • Fixes an appearance of Tests hang forever #694 caused by an infinite loop on pipe-args.js that doesn't break when there is no piped data; fs.readSync throws EAGAIN but it was being silently ignored.

Follow-ups


Note: this time I am erring on the opposite side and packing many loosely related changes together, because shipping them separately would involve lots of intermediate commits with useless, hand-tailored workarounds to keep everything working until the next one.

@0x2b3bfa0 0x2b3bfa0 self-assigned this Aug 31, 2021
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 13:31 Inactive
@0x2b3bfa0 0x2b3bfa0 added enhancement New feature or request technical-debt Refactoring, linting & tidying ui/ux User interface/experience labels Aug 31, 2021
@0x2b3bfa0 0x2b3bfa0 force-pushed the user-experience-improvements branch from 33bcce6 to 91ea5c9 Compare August 31, 2021 14:13
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 14:13 Inactive
Copy link
Contributor

@DavidGOrtega DavidGOrtega left a comment

Choose a reason for hiding this comment

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

Very nice!!!! 🚀

I think that we could do another iteration.

  • Args mostly repeats --repo --token etc...
  • I would put everything under CML.js exporting the parameters

What do you think?

Copy link
Contributor

@DavidGOrtega DavidGOrtega left a comment

Choose a reason for hiding this comment

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

Also, winston should cover every log, we do not have to it here but would be awesome if we do not forget a technical debt ticket

@0x2b3bfa0
Copy link
Member Author

Also, winston should cover every log, we do not have to it here but would be awesome if we do not forget a technical debt ticket

Yes, #22 states that we should «change every console.log into proper logger calls», but I have preserved some of them on the CLI part to output clean strings like publish asset addresses. Maybe we can create a new output log level to print raw lines. 🤔

@0x2b3bfa0
Copy link
Member Author

Args mostly repeats --repo --token etc...

Yes, I'm leaving that for another pull request, but we could move all the common arguments to the top level cml command.

@0x2b3bfa0
Copy link
Member Author

I would put everything under CML.js exporting the parameters

I would rather separate the command–line interface from cml.js as much as possible, so we have individual files for the commands/subcommands with only the user-facing API, and then all the business logic in the src directory. The old cml-pr command is a good example of this approach.

@DavidGOrtega
Copy link
Contributor

I would rather separate the command–line interface from cml.js as much as possible, so we have individual files for the commands/subcommands

Thats what I say, ideally we just only need one cli file if we expose the ARGS the CML.js module.
have a look 🙂

@0x2b3bfa0
Copy link
Member Author

0x2b3bfa0 commented Aug 31, 2021

Thats what I say, ideally we just only need one cli file if we expose the ARGS the CML.js module.
have a look 🙂

Ooops! My bad, I thought you mean src/cml.js and not bin/cml.js 🤦

Yes, we could move all the commands to the latter instead of having separate files, but I still would prefer to keep separate files for each subcommand; it feels cleaner to me. Nevertheless, we could extract the common options to bin/cml.js as you suggested and keep these files to a bare minimum.

@0x2b3bfa0 0x2b3bfa0 force-pushed the user-experience-improvements branch from 91ea5c9 to 8c1e5dc Compare August 31, 2021 15:30
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 15:30 Inactive
@0x2b3bfa0 0x2b3bfa0 force-pushed the user-experience-improvements branch from 8c1e5dc to 26be40d Compare August 31, 2021 15:36
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 15:37 Inactive
Copy link
Contributor

@casperdcl casperdcl left a comment

Choose a reason for hiding this comment

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

would've been better to split into separate PRs but whatever

Dockerfile Outdated
@@ -101,4 +101,4 @@ WORKDIR ${RUNNER_PATH}

# COMMAND
ENV IN_DOCKER=1
CMD ["cml-runner"]
CMD ["cml"]
Copy link
Contributor

Choose a reason for hiding this comment

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

perhaps something like this?

Suggested change
CMD ["cml"]
ENTRYPOINT ["/usr/bin/cml"]
CMD ["runner"]

Copy link
Member Author

Choose a reason for hiding this comment

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

Absolutely for using ENTRYPOINT as the entry point. 💯 Absolutely not for using runner as the default command; it doesn't make any sense (to my mind) and that behavior is not even documented.

Copy link
Member Author

Choose a reason for hiding this comment

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

Suggested change
CMD ["cml"]
ENTRYPOINT ["/usr/bin/cml"]

Copy link
Contributor

Choose a reason for hiding this comment

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

sure but one thing to note is pple who were overriding CMD with e.g. /bin/bash will now get an error. They'll have to switch to using --entrypoint /bin/bash instead.

Copy link
Contributor

Choose a reason for hiding this comment

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

Copy link
Member Author

Choose a reason for hiding this comment

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

docker run iterativeai/cml cml publish # CMD
docker run iterativeai/cml publish # ENTRYPOINT

Copy link
Contributor

Choose a reason for hiding this comment

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

I fiind this better:

docker run iterativeai/cml cml publish # CMD

than this:

docker exec myimage sh -c nvidia-smi

Copy link
Member Author

Choose a reason for hiding this comment

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

Why not have the best of both worlds?

docker run iterativeai/cml publish
docker run iterativeai/cml nvidia-smi

Copy link
Member Author

Choose a reason for hiding this comment

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

Applied with a536f07

Copy link
Contributor

@DavidGOrtega DavidGOrtega Sep 9, 2021

Choose a reason for hiding this comment

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

I think that a536f07 is misleading. cml does not support those commands, how is the user going to guess that docker hack? He is not be able to do that with standalone CML.
I do not think is is a good change. What do you think @casperdcl ?

@0x2b3bfa0
Copy link
Member Author

would've been better to split into separate PRs but whatever

I can still split them if you want, but #22 should be addressed after #699 lest writing a dozen of temporary workarounds.

@casperdcl
Copy link
Contributor

not worth the effort now :)

@0x2b3bfa0 0x2b3bfa0 mentioned this pull request Aug 31, 2021
@0x2b3bfa0 0x2b3bfa0 force-pushed the user-experience-improvements branch from 26be40d to 540d16e Compare August 31, 2021 21:24
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 21:24 Inactive
@0x2b3bfa0 0x2b3bfa0 force-pushed the user-experience-improvements branch from 540d16e to afa0f3d Compare August 31, 2021 21:37
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 21:37 Inactive
@0x2b3bfa0 0x2b3bfa0 force-pushed the user-experience-improvements branch from afa0f3d to 8b0c76a Compare August 31, 2021 21:41
@0x2b3bfa0 0x2b3bfa0 temporarily deployed to internal August 31, 2021 21:41 Inactive
@0x2b3bfa0 0x2b3bfa0 marked this pull request as ready for review August 31, 2021 21:47
@casperdcl casperdcl temporarily deployed to internal September 3, 2021 00:46 Inactive
Dockerfile Outdated Show resolved Hide resolved
Co-authored-by: Helio Machado <[email protected]>
@casperdcl casperdcl temporarily deployed to internal September 3, 2021 13:39 Inactive
@casperdcl casperdcl temporarily deployed to internal September 9, 2021 13:05 Inactive
@casperdcl casperdcl temporarily deployed to internal September 9, 2021 13:09 Inactive
@casperdcl casperdcl force-pushed the user-experience-improvements branch from 3756e81 to e27d337 Compare September 9, 2021 13:12
@casperdcl casperdcl temporarily deployed to internal September 9, 2021 13:12 Inactive
@casperdcl casperdcl merged commit 60ff630 into master Sep 9, 2021
@casperdcl casperdcl deleted the user-experience-improvements branch September 9, 2021 13:35
@casperdcl
Copy link
Contributor

@0x2b3bfa0 I'll leave you to open follow up issue(s)/epics

@0x2b3bfa0
Copy link
Member Author

I was doing exactly that 😄

@DavidGOrtega
Copy link
Contributor

To be honest, I do not consider the docker issue fixed to have merged this.
I would have leaved it at least as it was and do a new PR to attack it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request technical-debt Refactoring, linting & tidying ui/ux User interface/experience
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Unify commands under a single entry point Better logging
3 participants