Table of Contents
DeKick /də kɪk/ is a tool which supports and improves the work of dev team, by provisioning and building unified environments using Docker without being an expert. It relieves the pain of running projects locally on different platforms (Linux, Windows with WSL2 or macOS with Intel and ARM based CPUs) and prevents many common problems faced by developers when dockerizing their projects.
DeKick goes even further and helps to build target Docker images which can be deployed on a test, beta or even production environment with ease.
Therefore, it helps to reduce the time spent on setting up and configuring development environments and enables developers to quickly switch between projects or work on multiple projects simultaneously without any compatibility issues.
Transform the way developers work, giving them the freedom to run apps, ignite their coding passion, and bring their projects to life with effortless fixes and deployments.
- Differences in local environments between members of the same team, cause many additional issues.
- What worked locally doesn't work in other environments e.g. test, beta or production.
- Using Docker and dockerizing software needs additional knowledge.
- The need for assistance when a new developer approaches the project for the first time.
- Revisiting a project from years past, eager to make a small adjustment, only to be met with the frustration of being unable to launch it.
- The burden of installing numerous required software, including the correct versions of Node and PHP, along with additional software, and the hassle of setting it all up.
- The inconsistency in platforms used by dev team members, e.g. one using macOS with Apple M1 processor and the other using a unique Linux distribution, creating difficulties in installing required software and intensifying platform differences.
- Hardware failures exclude a developer from work for a significant period.
DeKick can be the answer when "It (locally) works for me" is not enough ;) It:
- Maintains consistency between team members' local setups and target environments.
- Allows you to run a project on a computer that has almost nothing on it, runs in dockerized environment as well, so it requires only Docker to operate and making it easy and fast to start (in minutes).
- Allows people who are not proficient in Docker commands to take advantage of the dockerized project.
- Eases onboarding for new team members and reduces dependence on senior deveSimplifies switching between projects with varying environment requirements. Work on multiple projects or revisit old ones seamlessly, without the need for constant local environment adjustments.
- Uses built in boilerplates to create basic file structure needed to quickly start your project, at the same time bringing standardization.
- Starts local database and seeds it with pre-set data (as specified by the chosen flavour)
- Runs backend and frontend simultaneously, at the same device, even if using different versions of, e.g. Node.
- Linux, Windows (with WSL2) or macOS (both Intel and ARM CPUs are supported)
- Docker Engine on Linux or Docker Desktop on macOS, Windows installed
- Terminal with
bash
orzsh
shell (other shell likefish
are not supported for now)
- DeKick uses small script (
dekick-docker.sh
) to rundesmart/dekick:develop
image that has already installed Python with the proper version as well as Python's packages neccessary to run DeKick. - Projects
dekick/
directory is mounted inside this image so current project's DeKick version is used. This allows to have different DeKick versions in different projects. DeKick images won't be deleted after release of the current version from Docker Hub so you can use older versions of DeKick if you like. You can even modify your local (project's) DeKick to whatever suits you and this one would be used.
- clone DeKick to your project's
dekick/
directory - in your terminal:
cd [YOUR_PROJECT_BASE_DIRECTORY]`
source dekick/dev
dekick install
(the install
command is planned for future releases, soon 🙂)
- answer some questions about the project, flavour, boilerplate etc.
- some new files should appear in your project (i.e.
.dekickrc.yml
,docker-compose.yml
,.gitlab-ci.yml
, depdends on the flavour and boilerplate you've chosen) - run
cd [YOUR_PROJECT_BASE_DIRECTORY]
source dekick/dev
dekick local
- commit everything
ment A local environment is this one that's run on developer's machine. One uses local version mostly for development of the application, so the tool provides an environment that closely mimics the production environment, allowing developers to test and debug their code under realistic conditions.
nd Assuming that you already have DeKick installed run following commands to start local environment:
cd [YOUR_PROJECT_BASE_DIRECTORY]
And then, when you are inside your project's base directory run:
source dekick/dev
This will make available dekick
command which will allow you to use it wherever you will change directory to (current terminal session only! If you want to open another terminal then you would have to run source dekick/dev
again)
Start local environment:
dekick local
DeKick will start the development enviromnent which depends on specific flavour. Typically, depending on the project size, project is ready to be developed in a matter of a couple of minutes (sometimes even under a minute).
nd
This command is used to run end-to-end tests using popular Cypress image (right now, it's our own Docker image based on Cypress included version). It runs cypress
tests inside a container.
For now, we support opening Cypress GUI and running tests on Linux and macOS only.
You need to have cypress/
directory with all the tests and typical Cypress directory structure inside your project. You can read more about Cypress here.
Also, there's a special cypress/cypress.config.template.js
file which is, when starting the container copied to cypress/cypress.config.js
file. You can use it to configure your Cypress tests and inject environment variables to them. Just add needed variables to .env
file in the root of your project and they will be available in cypress/cypress.config.js
file after starting the container.
For example file cypress/cypress.config.template.js
can look like this:
const { defineConfig } = require('cypress')
module.exports = defineConfig({
env: {
LOGIN_EMAIL: '${CYPRESS_LOGIN_EMAIL}',
LOGIN_PASSWORD: '${CYPRESS_LOGIN_PASSWORD}',
},
e2e: {
baseUrl: '${CYPRESS_BASE_URL}',
testIsolation: false,
chromeWebSecurity: false,
}
})
and .env
file can look like this:
CYPRESS_LOGIN_EMAIL=someuser@some-url.com
CYPRESS_LOGIN_PASSWORD=some-very-long-password
CYPRESS_BASE_URL=https://some-url.com
To run tests in headless mode (without opening Cypress GUI) run:
dekick e2e
this is equivalent to:
dekick e2e --mode run
To open Cypress GUI and run tests in interactive mode run:
dekick e2e --mode open
If you need to run (in headless mode) only specific test file then run:
dekick e2e --mode run --spec cypress/e2e/your-test.cy.js
Note that
--mode
option is optional, if you don't provide it thenrun
mode will be used by default.
Running tests on macOS will require to install
xquartz
package. You can install it usingbrew install xquartz
command or by downloading it from here.
) You can create global config file in your home directory in
.config/dekick/global.yml` file. This file will be used as a default config for all projects. The structure is following:
boilerplates:
git_url: [string, default: "" - URL to git repository with boilerplates]
gitlab:
token: [string, default: "" - Gitlab token with API access, needed for getting .env file from Gitlab]
dekick:
local:
disable_seed_ask: [boolean, default: false - if true then running `dekick local` will ommit the question about seeding database]
If the file doesn't exist then DeKick will use default values.
artisan
?
Hence DeKick is dockerized (runs inside a Docker container), in order to run commands like yarn
(for react flavour) or composer
(for laravel flavour) you have to run it using dekick
command. For example if you want to add lodash
package using yarn
then just run:
dekick yarn add lodash
This will run yarn
inside a proper container which your application is build with.
Note that above will only work with some flavours like
react
, runningdekick yarn
command onlaravel
flavour won't work because there is noyarn
command inside a node image.
DeKick runs in a container and you can run any command inside it. For example, if you want to run ls
command inside a container then just run:
dekick ls -l
Note that this is DeKick's own container, not the one with your application. If you want to run a shell inside a container with your application then run
dekick shell
command.
This will run ls -l
inside a proper container which your application is build with. By default it will run ls
in the project directory which is bind mounted inside the container in the same directory as your project. When you run source dekick/dev
you'll "lock" your project root path which will be the project you are in during source dekick/dev
.
Note: DeKick's using image based on docker:xx.xx.xx-cli-alpine
image which is based on Alpine Linux so you can use any command that is available in Alpine Linux.
If you get an error similar to this:
docker: Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post http://%2Fvar%2Frun%2Fdocker.sock/v1.35/containers/create: dial unix /var/run/docker.sock: connect: permission denied. See 'docker run --help'.
It means that docker
daemon does not have correct permissions to run. DeKick expects that you are managing docker as a non-root user by adding it to the docker
unix group. To create the docker group and add your user:
# Create the docker group.
sudo groupadd docker
# Add your user to the docker group.
sudo usermod -aG docker $USER
Please refer to post-installation steps and troubleshooting sections of the Docker documentation for more details.
This error can occur when trying to start a container that is configured to use a non-existent network. To resolve this issue, you can try the following steps:
- Check the name of the network you are trying to use. Make sure you have spelled the name correctly and that the network exists. You can check the list of available networks on your system by running the command:
docker network ls
- If the network does not exist, you can create it using the following command:
docker network create {NETWORK_NAME}
Replace {NETWORK_NAME}
with the name you want to give to the network.
However, this error can also be caused by issues with running containers or volumes as well. In this case, you may need to shut down all containers or remove unused volumes to resolve the issue. Additionally you may also restart Docker.
To shut down all running containers you can use:
docker ps -q | xargs docker kill
To remove unused volumes you can use:
docker system prune -a --volume
It is important to note that this command will remove all unused resources, so make sure that you don't have any important data stored in the volumes that you are removing.
To restart docker you need to use one of the follow instruction:
on macOS, Windows you can just restart Docker Desktop application
on Linux:
sudo systemctl restart docker
If you encounter an error and there is no specific information available, you should check the Docker container logs using the following command:
docker logs {CONTAINER_ID} -f
Replace {CONTAINER_ID}
with the ID
of the specific container you are interested in. This command will display the logs for the container, which may contain helpful information for troubleshooting the issue.
Thank you for your interest in contributing to DeKick! We welcome contributions from anyone, whether you are a seasoned developer or just starting out.
- Fork the repository to your own GitHub account.
- Clone the project to your local machine.
- Create a new branch with a descriptive name for your feature or bug fix.
- Make changes to the code, documentation, or tests.
- Test and debug your changes thoroughly to ensure they work as expected.
- Commit your changes and push them to your fork.
- Open a pull request in our repository and provide a brief description of the changes you have made.
- Wait for feedback or approval from the project maintainers.
- If the reviewing maintainer suggests any modifications to your pull request, then proceed to make those changes.
- Once your pull request has been merged, take the time to celebrate your accomplishment!
When contributing code to DeKick, please adhere to the following guidelines:
- Use clear and descriptive variable names.
- Write concise and well-documented code.
- Use consistent formatting and adhere to the project's existing style.
- Write tests for any new functionality you add.
- Remember to run tests regularly and to ensure that all tests pass before submitting a pull request. This will help ensure that the code is stable and meets the project's requirements.
Debugging DeKick can be done using an independent version of the tool. This is because using an independent version makes it easier to pinpoint the source of the error and to ensure that the code being debugged is the correct version.
To start debugging, follow these steps:
- Get an independent DeKick project repository that is not tied to a specific project on your local machine.
- Navigate to the project repository in which you can test DeKick with your changes.
- Run DeKick from the project repository using the command:
source ../../desmart-internal/dekick/dev
This command will ensure that you are running the independent version of DeKick and not the version installed in the project.
- Set the debugger flag and run DeKick using the command:
DEKICK_DEBUGGER=true dekick local
This will launch DeKick in local mode and allow you to step through the code and debug any issues that may arise.
DeKick uses the debugger from VS Code, which allows you to set breakpoints and step through the code line by line. Configuration for debugger you can find in a launch.json
file.
You can start the debugger by clicking on the RUN AND DEBUG
button in the debug panel. This will start the DeKick application in debugging mode.
In order to set breakpoints in the code you need to click on the left-hand margin in VS Code. When the application reaches a breakpoint, it will pause execution and you can inspect the state of the code and step through it line by line to identify any issues.
Debugging is an important tool for identifying and fixing issues in your code, and using the VS Code debugger in DeKick makes it easy to do so.
Testing DeKick is an important part of the development process, as it ensures that the code is functioning correctly and meets the project's requirements. In DeKick
we use pytest
with xdist
plugin, that allows you to run tests in parallel across multiple CPUs or machines.
When you run pytest
with xdist
enabled, it will distribute the tests across multiple workers (processes or threads)
and execute them simultaneously. The number of workers can be specified through the -n
option. By default, pytest-xdist
uses 2 threads for parallel test execution. One of the benefits of using xdist is that it can significantly reduce the execution time of test suites, especially for large projects with many tests.
Here's how to run tests on DeKick:
- To run tests in
DeKick
, navigate to the repository directory on your local machine. - Set up your environment: Before running the tests, you will need to set up your environment. Make sure that you have a
.env
file that contains the necessary environment variables, including theBOILERPLATES_GIT_URL
key which should contain the URL to the repository with the boilerplates connected. - Run all tests: To run all tests, use the command
dekick pytest
This command will run all tests in the repository and display the results.
- Run specific tests: If you want to run a specific test, use the command
dekick pytest tests/{CHOSEN_TEST}
Replace {CHOSEN_TEST}
with the name of the test file or test method that you want to run.
- Analyze test results: After running the tests, analyze the results to ensure that all tests pass and that the code is functioning as expected.
Boilerplates are starter kit projects that are used to test DeKick and to provide a starting point for new projects. These boilerplates are pre-configured projects that are set up to work with specific frameworks and technologies, such as React, Express, or PHP with Laravel framework.
Currently, the boilerplates used in the DeKick project are stored in a private repository. However, we plan to make these boilerplates available to all users in the future.
When you run DeKick, it uses these boilerplates to create a new project or to provision a development environment. This makes it easy to get started with a new project and ensures that the project is set up correctly from the start with the specific framework or technology that you have chosen.
Once the boilerplates are made public, you will be able to access them from the DeKick repository and use them for your own projects.
If you encounter any bugs or issues with DeKick, please report them using the project's issues. When reporting an issue, please provide as much detail as possible, including:
- A description of the problem you encountered.
- Steps to reproduce the issue.
- The version of DeKick you are using.
- Any relevant error messages or logs.
If you have any questions or need help with your contribution, you can reach out to the project maintainers on our mailing list (dooshek@desmart.com). We are happy to help and answer any questions you may have.
Thank you for your contributions and for helping to make DeKick better!