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

feat: add picasso commands in simple way #2

Merged
merged 25 commits into from
Aug 27, 2024
Merged

Conversation

MaferMazu
Copy link
Collaborator

@MaferMazu MaferMazu commented Aug 2, 2024

Description

This PR simply adds the following commands:

# Enable themes
tutor picasso enable-themes

# Enable private packages
tutor picasso enable-private-packages

# Run Tutor commands
tutor picasso run-extra-commands

For more information on how the plugin does it, follow the README.

How to test

Integration Tests

They are in the workflows.

Manually

  1. Create a redwood tutor env
  2. Install the plugin
pip install git+https://github.com/eduNEXT/tutor-contrib-picasso@mfmz/simple-picasso
  1. Verify everything is right with the base commands.
# To enable the plugin
tutor plugins enable picasso

# Show help
tutor picasso -h
  1. Add info in the config.yml, for example:
PICASSO_MANAGE_DPKG:
  name: eox-manage
  repo: git@github.com:eduNEXT/eox-manage.git
  version: v5.2.0
PICASSO_THEMES:
- name: endx-saas-themes
  repo: git@github.com:eduNEXT/ednx-saas-themes.git
  version: edunext/redwood.master
PICASSO_TENANT_DPKG:
  name: eox-tenant
  repo: git@github.com:eduNEXT/eox-tenant.git
  version: v11.7.0
PICASSO_EXTRA_COMMANDS:
- tutor plugins index add https://raw.githubusercontent.com/eduNEXT/tutor-plugin-indexes/main/
- tutor plugins install mfe mfe_extensions aspects
- tutor plugins enable mfe mfe_extensions aspects
- tutor picasso enable-themes
- tutor picasso enable-private-packages
- tutor config save
  1. Run the commands available. If you are following the example, you only need to run:
tutor picasso run-extra-commands

Support

✅ Tested in Redwood, Quince, Palm, and Olive.

Warning

We recommend Quince >= v17.0.3 because add an important fix related to the enable-private-package command. Ref: overhangio/tutor#1016

Warning

If you want to use tutor plugin indexes, you need an Olive tutor version >= 15.3.0. (With this plugin the tutor plugin indexes is the only way to install other tutor plugins)

Important notes, and I want your feedback about it

My proposal here does not follow the release convention of the tutor plugin. To avoid major release when it is not needed. Another plugin with this system is Aspects: https://github.com/openedx/tutor-contrib-aspects. So, this plugin should be compatible with Palm and Quince.

Another proposal is only having those three commands. The syntax-validator and repository-validator don't add functionality to the build. If we want to still use it, we can use it in the GA or Jenkins pipeline through the scripts we have here: https://github.com/eduNEXT/dedalo-scripts/tree/main/jenkins.

Another important change is I proposed to change the structure of the input:

DISTRO_MY_PACKAGE_NAME_DPKG:
  index: git
  name: eox-package # directory name
  # ---- git package variables
  repo: eox-package # git repository name
  domain: github.com
  path: eduNEXT
  protocol: ssh
  # ---- end git package variables
  version: master
  private: true
  variables:
    development: {}
    production: {}
  PICASSO_<YOUR_PACKAGE_NAME>_DPKG:
    name: <your_package_name>
    repo: <your SSH URL for cloning the repo. e.g., git@github.com:yourorg/package.git>
    version: <your branch, tag o release for cloning. e.g., v5.2.0>
DISTRO_THEMES:
  - domain: github.com
    name: my-theme
    path: my-account
    protocol: ssh
    repo: my-openedx-theme
    version: release-compatible
  PICASSO_THEMES:
    - name: <your_theme_name>
      repo: <your SSH URL for cloning the repo. e.g., git@github.com:yourorg/theme.git>
      version: <your branch, tag o release for cloning. e.g., edunext/redwood.master>
    - name: <another_theme_name>
      repo: <your SSH URL for cloning the repo. e.g., git@github.com:yourorg/another_theme.git>
      version: <your branch, tag o release for cloning. e.g., edunext/redwood.blue>

@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from 6e9c13c to c544e98 Compare August 2, 2024 04:13
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch 2 times, most recently from b0c99b2 to dceae00 Compare August 2, 2024 17:56
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from dceae00 to c740aa4 Compare August 2, 2024 17:58
@MaferMazu MaferMazu marked this pull request as ready for review August 2, 2024 18:17
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
tutorpicasso/commands/enable_private_packages.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch 2 times, most recently from 6d5ab6f to 4d3bf9f Compare August 16, 2024 17:06
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from 4d3bf9f to f977bd3 Compare August 16, 2024 17:25
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from 8d842b4 to 924b175 Compare August 16, 2024 18:32
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch 2 times, most recently from 83239a9 to 6b384ad Compare August 16, 2024 19:03
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from d07a938 to a078a8b Compare August 20, 2024 23:07
@MaferMazu
Copy link
Collaborator Author

I forget to mention this important proposal change:

I proposed to change the structure of the input:

DISTRO_MY_PACKAGE_NAME_DPKG:
  index: git
  name: eox-package # directory name
  # ---- git package variables
  repo: eox-package # git repository name
  domain: github.com
  path: eduNEXT
  protocol: ssh
  # ---- end git package variables
  version: master
  private: true
  variables:
    development: {}
    production: {}
  PICASSO_<YOUR_PACKAGE_NAME>_DPKG:
    name: <your_package_name>
    repo: <your SSH URL for cloning the repo. e.g., git@github.com:yourorg/package.git>
    version: <your branch, tag o release for cloning. e.g., v5.2.0>
DISTRO_THEMES:
  - domain: github.com
    name: my-theme
    path: my-account
    protocol: ssh
    repo: my-openedx-theme
    version: release-compatible
  PICASSO_THEMES:
    - name: <your_theme_name>
      repo: <your SSH URL for cloning the repo. e.g., git@github.com:yourorg/theme.git>
      version: <your branch, tag o release for cloning. e.g., edunext/redwood.master>
    - name: <another_theme_name>
      repo: <your SSH URL for cloning the repo. e.g., git@github.com:yourorg/another_theme.git>
      version: <your branch, tag o release for cloning. e.g., edunext/redwood.blue>

Copy link
Contributor

@mariajgrimaldi mariajgrimaldi left a comment

Choose a reason for hiding this comment

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

I left a few other suggestions for you to review and apply if you see fit. Thank you so much for addressing all my previous comments! Great work here :)

.github/workflows/integration_test.yml Outdated Show resolved Hide resolved
.github/workflows/integration_test.yml Show resolved Hide resolved
tutorpicasso/commands/enable_themes.py Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
@mariajgrimaldi
Copy link
Contributor

Thank you, @MaferMazu. Your proposal #2 (comment) looks way cleaner than what we currently use, so I have no objections.

@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from 1e326cf to e1ad584 Compare August 22, 2024 02:25
@Asespinel
Copy link

Asespinel commented Aug 22, 2024

Hello goodnight, I was following the instructions to test this plugin on the last redwood version (18.1.3) and when I try to enable the plugin using tutor plugins enable picasso I get the following error:

tutor plugins enable picasso
⚠️ Failed to enable plugin 'indigo': plugin 'indigo' is not installed.
⚠️ Failed to enable plugin 'mfe': plugin 'mfe' is not installed.
Error applying action: func=<function discover_package..load at 0x7f926ce698b0> contexts=['plugins']'
Traceback (most recent call last):
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/bin/tutor", line 8, in
sys.exit(main())
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/commands/cli.py", line 27, in main
cli() # pylint: disable=no-value-for-parameter
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/core.py", line 1157, in call
return self.main(*args, **kwargs)
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/core.py", line 1078, in main
rv = self.invoke(ctx)
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/core.py", line 1688, in invoke
return _process_result(sub_ctx.command.invoke(sub_ctx))
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/core.py", line 1688, in invoke
return _process_result(sub_ctx.command.invoke(sub_ctx))
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/core.py", line 1434, in invoke
return ctx.invoke(self.callback, **ctx.params)
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/core.py", line 783, in invoke
return __callback(*args, **kwargs)
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/click/decorators.py", line 33, in new_func
return f(get_current_context(), *args, **kwargs)
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/commands/plugins.py", line 141, in enable
plugins.load(plugin)
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/plugins/init.py", line 81, in load
hooks.Actions.PLUGIN_LOADED.do(name)
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/core/hooks/actions.py", line 116, in do
self.do_from_context(None, *args, **kwargs)
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/core/hooks/actions.py", line 135, in do_from_context
callback.do(
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/core/hooks/actions.py", line 36, in do
self.func(*args, **kwargs)
File "/home/andres/.tvm/v18.1.3@test-picasso/overhangio-tutor-3143335/tutor/plugins/v1.py", line 78, in load
importlib.import_module(entrypoint.value)
File "/usr/lib/python3.8/importlib/init.py", line 127, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "", line 1014, in _gcd_import
File "", line 991, in _find_and_load
File "", line 975, in _find_and_load_unlocked
File "", line 671, in _load_unlocked
File "", line 848, in exec_module
File "", line 219, in _call_with_frames_removed
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/tutorpicasso/plugin.py", line 12, in
from tutorpicasso.commands.cli import picasso
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/tutorpicasso/commands/cli.py", line 9, in
from tutorpicasso.commands.run_extra_commands import run_extra_commands
File "/home/andres/.tvm/v18.1.3@test-picasso/venv/lib/python3.8/site-packages/tutorpicasso/commands/run_extra_commands.py", line 127, in
def create_regex_from_list(special_chars: List[str]) -> re.Pattern[str]:
TypeError: 'type' object is not subscriptable

However, when I do tutor plugins list I do see the plugin installed.

Copy link
Contributor

@mariajgrimaldi mariajgrimaldi left a comment

Choose a reason for hiding this comment

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

I'll leave my approval once these last suggestions are addressed. Thank you!

Comment on lines 22 to 58
context = click.get_current_context().obj
tutor_root = context.root
tutor_conf = tutor_config.load(tutor_root)

tutor_version_obj = Version(tutor_version)
# Define Quince version as the method for installing private packages changes from this version
quince_version_obj = Version("v17.0.0")

# Use these specific paths as required by Tutor < Quince
private_requirements_root = f"{tutor_root}/env/build/openedx/requirements"
packages = get_picasso_packages(tutor_conf)

# Create necessary directory if it doesn't exist
if not os.path.exists(private_requirements_root):
os.makedirs(private_requirements_root)

for package, info in packages.items():
if not {"name", "repo", "version"}.issubset(info):
raise click.ClickException(
f"{package} is missing one of the required keys: 'name', 'repo', 'version'"
)

if os.path.isdir(f'{private_requirements_root}/{info["name"]}'):
subprocess.call(
["rm", "-rf", f'{private_requirements_root}/{info["name"]}']
)

subprocess.call(
["git", "clone", "-b", info["version"], info["repo"]],
cwd=private_requirements_root,
)

if tutor_version_obj < quince_version_obj:
private_requirements_txt = f"{private_requirements_root}/private.txt"
_enable_private_packages_before_quince(info, private_requirements_txt)
else:
_enable_private_packages(info, private_requirements_root)
Copy link
Contributor

Choose a reason for hiding this comment

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

What do you think about doing something like this: 7c6ccc3.

Copy link
Contributor

Choose a reason for hiding this comment

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

[nit] We're using both packages and requirements in naming. Could we decide whether to use packages or requirements?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Thanks a lot. I applied 7c6ccc3 and also refactored a little bit the names of the functions.

Regarding naming, I propose that in the context of Picasso, we use the name package (to read the package information and enable packages, but for the context of Tutor, we use the name requirements); I don't know if there is a good place to put it.

I maintained the package command to avoid being so far to tutor-contrib-edunext-distro; but later, we can question the use of package instead of requirements.

tutorpicasso/commands/run_extra_commands.py Outdated Show resolved Hide resolved
"Take a look at the official Tutor commands: "
"https://docs.tutor.edly.io/reference/cli/index.html"
)
return error_message
Copy link
Contributor

Choose a reason for hiding this comment

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

question: if multiple commands have errors, will this only return the first it encounters? what if returns them all 87e8503?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Thanks for this. I applied 87e8503 and applied a little fix. You can check and verify if everything is okay.

Copy link
Contributor

@bra-i-am bra-i-am left a comment

Choose a reason for hiding this comment

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

@MaferMazu, thanks a lot for this PR. I only pointed out some minor things

.github/workflows/integration_test.yml Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
Co-authored-by: Brayan Cerón <86393372+bra-i-am@users.noreply.github.com>
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from 1540bd4 to 0203763 Compare August 23, 2024 21:34
@MaferMazu
Copy link
Collaborator Author

@Asespinel, I couldn't replicate the error.

Step by step in local (It works):

tvm project init picasso_v1813 v18.1.3
cd picasso_v1813/
source .tvm/bin/activate 
pip install git+https://github.com/eduNEXT/tutor-contrib-picasso@mfmz/simple-picasso
tutor plugins enable picasso

Also, in the integration test, we test this plugin in Tutor == 18.1.3 in the <19.0.0 integration test. For more information: https://github.com/eduNEXT/tutor-contrib-picasso/actions/runs/10532688714/job/29187320715 (Or you can check the <19.0.0 integration test)

Please let me know if the problem persists.

@MaferMazu MaferMazu requested a review from bra-i-am August 26, 2024 16:38
@MaferMazu MaferMazu force-pushed the mfmz/simple-picasso branch from 9cf3ec5 to 5d8dc5b Compare August 26, 2024 21:24
Copy link
Contributor

@mariajgrimaldi mariajgrimaldi left a comment

Choose a reason for hiding this comment

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

Thank you so much for addressing all my comments. LGTM!

@MaferMazu
Copy link
Collaborator Author

@Asespinel I already fix the problem. I couldn't replicate it before because I was using Python 3.10, and the issue was for version < 3.9. It was because I couldn't call re.Pattern[str]. Now, I am using Pattern from typing. You should be able to try it now.

Copy link
Contributor

@bra-i-am bra-i-am left a comment

Choose a reason for hiding this comment

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

LGTM! 👯

@MaferMazu MaferMazu merged commit bf51ed8 into main Aug 27, 2024
7 checks passed
@MaferMazu MaferMazu mentioned this pull request Aug 28, 2024
2 tasks
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.

4 participants