Skip to content

Latest commit

 

History

History
170 lines (119 loc) · 4.31 KB

HOW-TO-USE.md

File metadata and controls

170 lines (119 loc) · 4.31 KB

How to use

The PrestaShop Docker tool aims to easily configure, build and tag PrestaShop Docker images. It requires Python 3.6+.

Installation

$ pip install -r requirements.txt --break-system-packages

Usage

Display the help:

$ ./prestashop_docker.py --help
usage: prestashop_docker.py [-h] [--debug] [--cache] [subcommand] ...

PrestaShop Docker manager.

positional arguments:
  [subcommand]
    tag         Tag managment
    generate    Generate Dockerfile

optional arguments:
  -h, --help    show this help message and exit
  --debug       Use Debug
  --cache    Enable cache

Generate

It allows you to generate Dockerfile files related on what you defined in versions.py file.

$ ./prestashop_docker.py generate --help
usage: prestashop_docker.py generate [-h]

optional arguments:
  -h, --help  show this help message and exit

Tag

It builds docker images on local et allows you to push them on DockerHub.

$ ./prestashop_docker.py tag --help
usage: prestashop_docker.py tag [-h] {exists,build,push,aliases} ...

positional arguments:
  {exists,build,push,aliases}
    exists              Check if tag exists on Docker Hub
    build               Build container and create docker tag
    push                Push docker tags
    aliases             Get aliases

optional arguments:
  -h, --help            show this help message and exit

Using docker compose

To generate the new base files, you need to update the versions.py file, add a section ith your new version along with the associated PHP versions, then run

docker compose up generate

This will create new folders for the new version you just added.

Running tests locally

To run the python tests you need to install requirements

$ pip install -r requirements.txt

Then you can run the tests:

$ nosetests

Locally you may have an error like ``, running these commands may help running tests locally:

$ pip uninstall -y nose
$ pip install -U nose --no-binary :all:

or alternatively:

$ pip install nose-py3

If you need to debug one specific test you first need to run

$ nosetests --with-id

This will execute tests and each test method will be assigned an ID that you can then use to filter it specifically:

$ nosetests --with-id 7

This will also generate a .nodeids binary file, when you add new test methods you need to remove this file to re-generate the list of IDs.

Building and running PrestaShop docker locally

First to make sure you will use the local docker containers and not the ones from Docker hub make sure you remove all existing PrestaShop images (including the base images)

# This should be empty to be extra sure
$ docker images

Then you'll have to build the base image for the PHP version and server you are willing to use. If you are on MacOS this is crucial that you clean any image from cache and tun this locally, especially if your architecture is based on linux/arm64 (processor M1, M2, ...).

docker build base/images/8.3-apache -t prestashop/base:8.3-apache
# You should see an image with Repository: prestashop Tag: 8.3-apache
docker images

Then you can build the image of the PrestaShop version you want to use:

# Now build the PrestaShop version you want based on this local base image
$ docker build images/9.0.x/8.3-apache -t prestashop/prestashop:9.0.x-8.3-apache

Finally, you can launch your PrestaShop container using docker compose

$ PS_VERSION=9.0.x PHP_VERSION=8.3 docker compose -f images/docker-compose.yml up

Or you can use the build-local-docker.sh script that performs these actions based on the options

# Script options:
#
# -v PRESTA_SHOP_VERSION
# -s SERVER (apache|fpm)
# -p PHP_VERSION (7.1, 8.2, ...)
# -l Launch shop thanks to a docker compose (default false)
#
# Default values are nightly 8.3 apache

$ ./build-local-docker.sh -v 9.0.x -p 8.1 -s fpm

Adding the -l option will also launch a container build with docker compose so you get an accessible shop locally

$ ./build-local-docker.sh -v 9.0.x -p 8.1 -s fpm -l

Now you should be able to access a shop at this address: http://localhost:8001/ The BO is accessible at http://localhost:8001/admin-dev with the following login: Email: demo@prestashop.com Password: Correct Horse Battery Staple