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

Tools vs. Actions #671

Open
janpio opened this issue Aug 10, 2018 · 2 comments
Open

Tools vs. Actions #671

janpio opened this issue Aug 10, 2018 · 2 comments

Comments

@janpio
Copy link
Member

janpio commented Aug 10, 2018

After @taquitos and @joshdholtz convinced me that documenting the tools is not the way to go, I spent some time understanding what is still missing to fully transition from tools to actions.

Current state

  • CLI command: fastlane gym
  • Configuration file: Gymfile
  • Action: build_ios_app (+ gym alias)
  • Action via CLI: fastlane run build_ios_app

Problems

  1. Not all available tool CLI (sub)commands have an action
  2. Configuration files are named after tools
    • Some actions have a config file, others don't (gym .vs gradle)
  3. CLI tool command (fastlane gym) vs. run action (fastlane run build_ios_app)
  4. Other
    • SnapshotHelper.swift
    • init subcommands don't exist as action concept
    • Action documentation is tool branded
    • Change is bad

Possible Solutions

  1. Create more actions so all (sub)commands are covered
    • New actions could be "grouped" with existing action somehow, e.g. "Apple Developer Portal" for produce, in the documentation for example
  2. Find a way to "untool" configuration files
    • Configfile that combines all of them?
  3. Unify command and action execution via CLI
    • We can already use fastlane tool and fastlane lane, maybe also fastlane action?
  4. Other
    • SnapshotHelper.swift could be renamed e.g. ScreenshotHelper.swift
    • No idea how to deal with init. Just docs maybe? Magic action name init_build_ios_app for build_ios_app?
    • Documentation can remove all tool mentions and logos (besides a new History article that keeps the memory alive)
    • Of course all the former names, commands and configuration files keep working

Consequential work / problems

  • Github prefix and label ("[supply] ...", "tool:supply")
  • Changelog prefix ("[supply]")
  • I am not sure interfaces of all existing CLI commands and actions combination are identical, but goal would probably be: CLI command is identical to action

For reference:

List of tools and Configfiles in use:
https://github.com/fastlane/fastlane/blob/master/fastlane/lib/fastlane/tools.rb

@janpio
Copy link
Member Author

janpio commented Aug 10, 2018

I created a Google table with all the documented (sub)commands and brainsstormed possible action names for those that don't have one yet:
https://docs.google.com/spreadsheets/d/1HnflxsVyuj1nprHqE5uMnHsuiQ5SQRdZ-0Z6x8B4og4/edit?usp=sharing
This also includes more ideas about the "Group" names for actions that would be useful in the docs.

@janpio
Copy link
Member Author

janpio commented Aug 13, 2018

If this is done a a part of a major fastlane version, one could very much use the opportunity to get rid of many "tool" folders in fastlane/fastlane and convert them to simple actions. (Some of the old tools probably have some additional logic in their folders that would have to be taken care of [e.g. Android library for screengrab])

janpio added a commit to fastlane/fastlane that referenced this issue Sep 29, 2018
…stlane supply init` does as a command (#13113)

This is a proof of concept for one of the ideas I suggested in fastlane/docs#671: adding actions for all the `fastlane <toolname> init` commands that do more than creating a config file.

- Similar to `upload_to_play_store` this is a thin wrapper around the code that is already present in `supply`. 
- To make the options list more manageable, I hardcoded a manual list of options this action actually needs and removed all the others.
- As the action doesn't contain its actual code, I had to exclude it from the check in `fastlane/spec/unused_options_spec.rb` as well.
minuscorp pushed a commit to minuscorp/fastlane that referenced this issue Jul 18, 2020
…stlane supply init` does as a command (fastlane#13113)

This is a proof of concept for one of the ideas I suggested in fastlane/docs#671: adding actions for all the `fastlane <toolname> init` commands that do more than creating a config file.

- Similar to `upload_to_play_store` this is a thin wrapper around the code that is already present in `supply`. 
- To make the options list more manageable, I hardcoded a manual list of options this action actually needs and removed all the others.
- As the action doesn't contain its actual code, I had to exclude it from the check in `fastlane/spec/unused_options_spec.rb` as well.
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

No branches or pull requests

1 participant