mirror of
				https://github.com/ARM-software/workload-automation.git
				synced 2025-10-25 21:24:12 +01:00 
			
		
		
		
	Set DEBIAN_FRONTEND to prevent waiting on user input and provide a default timezone before package installation.
		
			
				
	
	
		
			149 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
| # This Dockerfile creates an image for use with Workload Automation
 | |
| # and/or devlib.
 | |
| #
 | |
| # To build this Docker image, please run the following command from
 | |
| # this directory:
 | |
| #
 | |
| #   docker build -t wa .
 | |
| #
 | |
| # This will create an image called wa, which is preconfigured to
 | |
| # run WA and devlib. Please note that the build process automatically
 | |
| # accepts the licenses for the Android SDK, so please be sure that you
 | |
| # are willing to accept these prior to building and running the image
 | |
| # in a container.
 | |
| #
 | |
| # To run the container, please run the following command from the
 | |
| # directory you wish to work from:
 | |
| #
 | |
| #   docker run -it --privileged -v /dev/bus/usb:/dev/bus/usb --volume ${PWD}:/workspace --workdir /workspace wa
 | |
| #
 | |
| # If using selinux you may need to add the `z` option when mounting
 | |
| # volumes e.g.:
 | |
| #   --volume ${PWD}:/workspace:z
 | |
| # Warning: Please ensure you do not use this option when mounting
 | |
| # system directores. For more information please see:
 | |
| # https://docs.docker.com/storage/bind-mounts/#configure-the-selinux-label
 | |
| #
 | |
| # The above command starts the container in privileged mode, with
 | |
| # access to USB devices. The current directory is mounted into the
 | |
| # image, allowing you to work from there. Any files written to this
 | |
| # directory are directly written to the host. Additional "volumes",
 | |
| # such as required assets, can be mounted into the container using a
 | |
| # second --volume command.
 | |
| #
 | |
| # If you require access to a TTY from the Docker container, please
 | |
| # also mount this into the container in the same style as is used to
 | |
| # mount USB devices. For example:
 | |
| #
 | |
| #   docker run -it --privileged -v /dev/ttyUSB0:/dev/ttyUSB0 -v /dev/bus/usb:/dev/bus/usb --volume ${PWD}:/workspace --workdir /workspace wa
 | |
| #
 | |
| # When you are finished, please run `exit` to leave the container.
 | |
| #
 | |
| # The relevant environment variables are stored in a separate
 | |
| # file which is automatically sourced in an interactive shell.
 | |
| # If running from a non-interactive environment this can
 | |
| # be manually sourced with `source /home/wa/.wa_environment`
 | |
| #
 | |
| # NOTE: Please make sure that the ADB server is NOT running on the
 | |
| # host. If in doubt, run `adb kill-server` before running the docker
 | |
| # container.
 | |
| #
 | |
| 
 | |
| # We want to make sure to base this on a recent ubuntu release
 | |
| FROM ubuntu:20.04
 | |
| 
 | |
| # Please update the references below to use different versions of
 | |
| # devlib, WA or the Android SDK
 | |
| ARG DEVLIB_REF=v1.3
 | |
| ARG WA_REF=v3.3
 | |
| ARG ANDROID_SDK_URL=https://dl.google.com/android/repository/sdk-tools-linux-3859397.zip
 | |
| 
 | |
| # Set a default timezone to use
 | |
| ENV TZ=Europe/London
 | |
| 
 | |
| ARG DEBIAN_FRONTEND=noninteractive
 | |
| RUN apt-get update && apt-get install -y \
 | |
| apache2-utils \
 | |
| bison \
 | |
| cmake \
 | |
| curl \
 | |
| emacs \
 | |
| flex \
 | |
| git \
 | |
| libcdk5-dev \
 | |
| libiio-dev \
 | |
| libxml2 \
 | |
| libxml2-dev \
 | |
| locales \
 | |
| nano \
 | |
| openjdk-8-jre-headless \
 | |
| python3 \
 | |
| python3-pip \
 | |
| ssh \
 | |
| sshpass \
 | |
| sudo \
 | |
| trace-cmd \
 | |
| usbutils \
 | |
| vim \
 | |
| wget \
 | |
| zip
 | |
| 
 | |
| # Clone and download iio-capture
 | |
| RUN git clone -v https://github.com/BayLibre/iio-capture.git /tmp/iio-capture && \
 | |
|     cd /tmp/iio-capture && \
 | |
|     make && \
 | |
|     make install
 | |
| 
 | |
| RUN pip3 install pandas
 | |
| 
 | |
| # Ensure we're using utf-8 as our default encoding
 | |
| RUN locale-gen en_US.UTF-8
 | |
| ENV LANG en_US.UTF-8
 | |
| ENV LANGUAGE en_US:en
 | |
| ENV LC_ALL en_US.UTF-8
 | |
| 
 | |
| # Let's get the two repos we need, and install them
 | |
| RUN git clone -v https://github.com/ARM-software/devlib.git /tmp/devlib && \
 | |
|     cd /tmp/devlib && \
 | |
|     git checkout $DEVLIB_REF && \
 | |
|     python3 setup.py install && \
 | |
|     pip3 install .[full]
 | |
| RUN git clone -v https://github.com/ARM-software/workload-automation.git /tmp/wa && \
 | |
|     cd /tmp/wa && \
 | |
|     git checkout $WA_REF && \
 | |
|     python3 setup.py install && \
 | |
|     pip3 install .[all]
 | |
| 
 | |
| # Clean-up
 | |
| RUN rm -R /tmp/devlib /tmp/wa
 | |
| 
 | |
| # Create and switch to the wa user
 | |
| RUN useradd -m -G plugdev,dialout wa
 | |
| USER wa
 | |
| 
 | |
| # Let's set up the Android SDK for the user
 | |
| RUN mkdir -p /home/wa/.android
 | |
| RUN mkdir -p /home/wa/AndroidSDK && cd /home/wa/AndroidSDK && wget $ANDROID_SDK_URL -O sdk.zip && unzip sdk.zip
 | |
| RUN cd /home/wa/AndroidSDK/tools/bin && yes | ./sdkmanager --licenses && ./sdkmanager platform-tools && ./sdkmanager 'build-tools;27.0.3'
 | |
| 
 | |
| # Download Monsoon
 | |
| RUN mkdir -p /home/wa/monsoon
 | |
| RUN curl https://android.googlesource.com/platform/cts/+/master/tools/utils/monsoon.py\?format\=TEXT | base64 --decode > /home/wa/monsoon/monsoon.py
 | |
| RUN chmod +x /home/wa/monsoon/monsoon.py
 | |
| 
 | |
| # Update WA's required environment variables.
 | |
| RUN echo 'export PATH=/home/wa/monsoon:${PATH}' >> /home/wa/.wa_environment
 | |
| RUN echo 'export PATH=/home/wa/AndroidSDK/platform-tools:${PATH}' >> /home/wa/.wa_environment
 | |
| RUN echo 'export PATH=/home/wa/AndroidSDK/build-tools:${PATH}' >> /home/wa/.wa_environment
 | |
| RUN echo 'export ANDROID_HOME=/home/wa/AndroidSDK' >> /home/wa/.wa_environment
 | |
| 
 | |
| # Source WA environment variables in an interactive environment
 | |
| RUN echo 'source /home/wa/.wa_environment' >> /home/wa/.bashrc
 | |
| 
 | |
| # Generate some ADB keys. These will change each time the image is build but will otherwise persist.
 | |
| RUN /home/wa/AndroidSDK/platform-tools/adb keygen /home/wa/.android/adbkey
 | |
| 
 | |
| # We need to make sure to add the remote assets too
 | |
| RUN wa --version && echo 'remote_assets_url: https://raw.githubusercontent.com/ARM-software/workload-automation-assets/master/dependencies' >> /home/wa/.workload_automation/config.yaml
 | |
| 
 |