Skip to content
This repository has been archived by the owner on Oct 5, 2022. It is now read-only.

Docker example for building theia from sources #439

Closed
MatejKastak opened this issue Nov 15, 2020 · 7 comments
Closed

Docker example for building theia from sources #439

MatejKastak opened this issue Nov 15, 2020 · 7 comments

Comments

@MatejKastak
Copy link

Hello,

my goal is to build a docker container with theia from sources, meaning that for example I would build current master with some custom patches/commits. I wasn't able to find an example how to do this.

I will gladly contribute example like this (maybe it will be useful also to others). But I don't have much experience with Js/Ts project that are this complex, so I would welcome any guidance.

It should be sufficient to create bare theia container, that would git clone theia-repo and then build it instead of using packages from npm. This way users can substitute their own repo or do anything with cloned sources. I know about the next version tag, but I believe it's not relevant in this usecase.

I think example like this can fit into additional-docker-examples section in README.

I have followed Developing.md and also tried to work with theia-cli.

Any suggestions appreciated.

@vince-fugnitto
Copy link
Member

I'm not sure the example would be useful for others (since it is not the recommended way of building an application as it offers no ability to modify/extend it easily). I also believe the example is quite simply. The idea would be to clone the main repository in the container, build it, and start it. In theia-apps we define a package.json of custom applications, but for this use-case we would not pull from npm but rather clone the repo. I'm not sure where the actual difficulty lies.

@MatejKastak
Copy link
Author

Thanks for your response.

but for this use-case we would not pull from npm but rather clone the repo. I'm not sure where the actual difficulty lies.

I understand what you mean by this, but I am not able to get it to work. Can you please share with me some links or documentation on how to achieve this (I tried yarn link with no success)? Any help is appreciated. I would like to build the master theia and then use packages built in this step to build my custom application.

I imagine Dockerfile can look something like this (pseudo code):

  1. Setup the system dependecies (for example based on https://github.com/theia-ide/theia-apps/blob/master/theia-docker/Dockerfile)

  2. RUN git clone https://github.com/eclipse-theia/theia /home/app/theia

  3. RUN cd /home/app/theia && yarn

  4. ADD package.json /home/app/custom-browser/package.json

  5. RUN ??? <build theia app using dependencies from /home/app/theia> It is not very clear to me how to build the theia application using the dependencies I have built in /home/app/theia

  6. Somehow start the custom theia app, I tried multiple approaches

  • ENTRYPOINT ["node", "/home/app/custom-browser/src-gen/backend/main.js", "/home/project", "--hostname=0.0.0.0"]
  • ENTRYPOINT ["yarn", "run", "start:browser", "--hostname=0.0.0.0"]

Example directory structure

home
└── app
    ├── custom-browser
    │   └── package.json   # package json for my custom app, with plugin definitions and such
    └── theia              # git clone https://github.com/eclipse-theia/theia

@marcdumais-work
Copy link
Member

Hi @MatejKastak,

Interesting idea. One unknown in my mind is how to strip the example browser application so we can use it in the container, hopefully without carrying the whole built repo, in the image.

In any case I think it should not be too hard to do. Do you have a starting point, maybe a prototype you attempted, that we could help fix instead of starting from scratch?

@MatejKastak
Copy link
Author

MatejKastak commented Dec 1, 2020

Hi @marcdumais-work , thanks for the response.

I have created a commented minimal example @ https://github.com/MatejKastak/theia-build-test . You can build it with make build and then test it with make run.

Currently this makes a valid browser application, but I don't think it uses the node modules built from sources.

What do you suggest? Can you see any outright mistakes? I am using yarn link which might be not correct. Maybe a little pseudo parallel with python with what I am trying to achieve 🙂 :

python -m venv env # I would create a virual-env
source env/bin/activate # Load the virtual env, for subsequent commnads
cd /theia && python setup.py install # Build and install theia
cd /app && python setup.py install # ~ This would use the installed theia in virtual env instead of downloading a new one

@marcdumais-work
Copy link
Member

@MatejKastak I have just documented a way to do something I think similar to what you want to achieve. I did it in a Gitpod container, but you could do it locally. In short I publish an arbitrary version of Theia in a local registry (verdaccio) and then build a Theia app from what I published:
eclipse-theia/theia#8880 (comment)

@marcdumais-work
Copy link
Member

marcdumais-work commented Jan 18, 2021

Hi @marcdumais-work , thanks for the response.

I have created a commented minimal example @ https://github.com/MatejKastak/theia-build-test . You can build it with make build and then test it with make run.

Currently this makes a valid browser application, but I don't think it uses the node modules built from sources.

What do you suggest? Can you see any outright mistakes?

I had a quick look and thought I did not see any outright mistakes, I have the feeling that you may be close to a solution, or that it should be possible to do something like this. But consider the local registry option above, too.

@stale
Copy link

stale bot commented Mar 20, 2021

This contribution has been automatically marked as stale due to inactivity, and it will be closed if no further activity occurs. Thank you for contributing to Theia!

@stale stale bot added the stale label Mar 20, 2021
@stale stale bot closed this as completed Jun 2, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

3 participants