Skip to content
This repository has been archived by the owner on Apr 4, 2023. It is now read-only.

Add devfile and doc for developing of Che Theia remote plugin mechanism #413

Merged
merged 4 commits into from
Sep 10, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
39 changes: 36 additions & 3 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,16 @@
Contribute to Che-Theia
================

Table of contents

- [Introduction](#introduction)
- [Devfiles](#devfiles)
- [Contribute to Theia or Che-Theia extensions or built-in Che-Theia plugins](#contribute-to-theia-or-che-theia-extensions-or-built-in-che-theia-plugins)
- [Just want to build the plugin and run with the existing Theia image](#just-want-to-build-the-plugin-and-run-with-the-existing-theia-image)
- [How to develop Che Theia remote plugin mechanism](#how-to-develop-che-theia-remote-plugin-mechanism)

## Introduction

There are 3 contribution points:
- Theia
- Che-Theia extensions
Expand All @@ -19,7 +29,7 @@ Devfile could be launched through a factory or [chectl](https://github.com/che-i
$ chectl workspace:start -f devfiles/che-theia-all.devfile.yaml
```

## Devfile for contributing to Theia or Che-Theia extensions or Che-plugins
## Contribute to Theia or Che-Theia extensions or built-in Che-Theia plugins
> Note that this devfile is going to evolve very soon and be splitted into multiple devfiles.

The devfile: [<this.repo>/devfiles/che-theia-all.devfile.yaml](./devfiles/che-theia-all.devfile.yaml)
Expand Down Expand Up @@ -129,10 +139,33 @@ To start che-theia in `dev-mode` with yarn (not using the production che-theia g
Running dev theia would be located in the che-dev container and `theia-dev-flow` endpoint:
![Che-Theia-dev-endpoint](https://raw.githubusercontent.com/eclipse/che-theia/assets/theia-dev-flow-endpoint.png)



### Just want to build the plugin and run with the existing Theia image
If you do not have any changes on Theia or Che-theia extension, you could just build the plugins with `build ... containers-plugin` or `build ... factory-plugin`
and run these plugins with the existing che-theia app:
`run ... HOSTED che-theia + container-plugin` or `run ... HOSTED che-theia + factory-plugin`


## How to develop Che Theia remote plugin mechanism

_Please note, this section provides a flow how to develop remote plugin mechanism in Che Theia, but not a remote plugin._

First, create a workspace from prepared [devfile](https://github.com/eclipse/che-theia/blob/master/extensions/eclipse-che-theia-plugin-remote/devfile.yaml), which could be found in the `eclipse-che-theia-plugin-remote` extension folder.
When workspace is ready:
- Init Che Theia. This could be done with `che:theia init` command in `/projects/theia` folder or run the init command.
Che Theia sources will be awailable at `/projects/theia/che/che-theia`.
- Now one may make changes in Che Theia remote plugin mechanism in both (Che Theia and Remote plugin) sides.
- Build Che Theia from `theia-dev` container by executing `yarn` in `/projects/theia` folder or by running corresponding command.
- Put binaries (*.theia or *.vsix) of your remote plugin(s) into `/projects/remote-plugins/` directory.
Note that the plugin(s) shouldn't have any external dependencies.
For example, [this sample plugin](https://github.com/eclipse/che-theia-samples/tree/master/samples/hello-world-backend-plugin) might be used.
mmorhun marked this conversation as resolved.
Show resolved Hide resolved
Or a user may generate one using `Generate Hello World plugin package` command.
- Run dev Che Theia and Remote plugins endpoint in `theia-dev` and `theia-remote-runtime-dev` containers correspondingly.
One may use predefined commands to start them.
- Open `theia-dev` route from `My Workspace` panel and test chenges.

Also it is possible to run watchers for remote plugin mechanism.
In `theia-dev` container run `npx run watch @eclipse-che/theia-remote` from `/projects/theia` folder to recompile the extension on changes made.
Also run `yarn watch` in `/projects/theia/examples/assembly` to bring the changes to Che Theia binaries.
If needed one may start watchers in plugin API extension: `npx run watch @theia/plugin-ext` from `/projects/theia` directory.
The commands for these actions are also available.
But please note, you have to restart server to which changes is made.
100 changes: 100 additions & 0 deletions extensions/eclipse-che-theia-plugin-remote/devfile.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,100 @@
apiVersion: 1.0.0
metadata:
name: che-theia-remote-dev
projects:
- name: theia
source:
type: git
location: 'https://github.com/theia-ide/theia.git'
components:
- type: cheEditor
id: eclipse/che-theia/next
alias: theia-editor
- type: chePlugin
id: eclipse/che-machine-exec-plugin/next
- type: chePlugin
id: che-incubator/typescript/latest
memoryLimit: 2Gi
- type: dockerimage
image: eclipse/che-theia-dev:next
alias: theia-dev
mountSources: true
env:
- name: THEIA_PLUGIN_ENDPOINT_DISCOVERY_PORT
value: '2504'
memoryLimit: 3Gi
- type: dockerimage
image: eclipse/che-theia-dev:next
alias: theia-remote-runtime-dev
mountSources: true
env:
- name: THEIA_PLUGIN_ENDPOINT_DISCOVERY_PORT
value: '2504'
- name: THEIA_PLUGINS
value: 'local-dir:///projects/remote-plugins/'
memoryLimit: 1Gi
commands:
- name: Init Che Theia
actions:
- type: exec
component: theia-dev
command: 'che:theia init'
workdir: /projects/theia
- name: Clean Che Theia
actions:
- type: exec
component: theia-dev
command: 'che:theia clean'
workdir: /projects/theia
- name: Generate Hello World plugin package
actions:
- type: exec
component: theia-dev
command: 'yes | yo @theia/plugin && cp y/y.theia /projects/remote-plugins/hello-world-plugin.theia && rm -rf /tmp/y'
workdir: /tmp
- name: Build Che Theia
actions:
- type: exec
component: theia-dev
command: 'yarn'
workdir: /projects/theia
- name: Watch changes in Theia Remote Extension
actions:
- type: exec
component: theia-dev
command: 'npx run watch @eclipse-che/theia-remote'
workdir: /projects/theia
- name: Watch changes in Theia Plugin API Extension
actions:
- type: exec
component: theia-dev
command: 'npx run watch @theia/plugin-ext'
workdir: /projects/theia
- name: Watch changes in Theia assembly
actions:
- type: exec
component: theia-dev
command: 'yarn watch'
workdir: /projects/theia/examples/assembly
- name: Run Dev Theia
actions:
- type: exec
component: theia-dev
command: 'yarn theia start --hostname=0.0.0.0 --port=3130'
workdir: /projects/theia/examples/assembly
- name: Run Remote Theia Plugin Endpoint
actions:
- type: exec
component: theia-remote-runtime-dev
command: 'node plugin-remote.js'
workdir: /projects/theia/che/che-theia/extensions/eclipse-che-theia-plugin-remote/lib/node
- name: Terminate all in Dev Theia
actions:
- type: exec
component: theia-dev
command: 'killall node'
- name: Terminate all in Remote Theia Plugin Endpoint
actions:
- type: exec
component: theia-remote-runtime-dev
command: 'killall node'