Custom Docker image not rebuild correctly after merging
Bug description
We have a very strange behavior with our Gitpod Setup using a custom Dockerfile. We have a main branch A and a feature branch B. In B we're testing some new things so the Dockerfile differs slightly but is mainly equal to A. From time to time, we merge the main branch A into the feature branch B to keep it up to date. In this case, the Docker Image is rebuild for B, but with the Dockerfile from A. Sounds confusing? Yes it is :lau
I described the steps using a minimal example to show the problem:
Steps to reproduce
- Create a project with these two files (main):
# .gitpod.Dockerfile
FROM gitpod/workspace-base:latest
RUN touch main-branch.info
# .gitpod.yml
image:
file: .gitpod.Dockerfile
-
Start a Gitpod workspace for main ->
ls ~should show onlymain-branch.info -
Create a Feature Branch (test-branch) and change the Dockerfile to:
# .gitpod.Dockerfile
FROM gitpod/workspace-base:latest
RUN touch main-branch.info
RUN touch test-branch.info
-
Start a Gitpod workspace for test-branch ->
ls ~should showmain-branch.infoandtest-branch.info-> So far everything is fine -
Make a change to Dockerfile in main:
# .gitpod.Dockerfile
FROM gitpod/workspace-base:latest
RUN touch main-branch-refactored.info
-
Start a Gitpod workspace for main ->
ls ~should show onlymain-branch-refactored.info -
Merge main into test-branch:
-
Start a Gitpod workspace for test-branch ->
ls ~showsmain-branch-refactored.infobut not test-branch.info ⚠️
That's already confusing, as the code now doesn't represent the state anymore. So I tried rebuilding the image explicitely:
- Open
https://gitpod.io/#imagebuild/https://gitlab.com/<group>/<project>/-/tree/test-branch-> Image is rebuild (you can see the logs, but you can see it's the wrong Dockerfile from main) ->ls ~showsmain-branch-refactored.infobut not test-branch.info ⚠️
The only thing that helps now is changing some line in the Dockerfile in test-branch. But this can't be the solution honestly.
Workspace affected
No response
Expected behavior
- [ ] When the Dockerfile changes (no matter if directly in the branch or through a merge from main branch), the Image should be rebuild correctly from the branch's Dockerfile
- [ ] When I use https://gitpod.io/#imagebuild/, I expect the rebuild to be base on the branch's Dockerfile
Example repository
No response
Anything else?
No response
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions.
Did anybody had a chance to take a look at that?