-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdockerfile
69 lines (54 loc) · 2.78 KB
/
dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
FROM aiplanning/planutils
# build command:
# docker build . -t scoping:sans_enhsp --progress=plain
# --progress-plain is needed to see echos. See https://stackoverflow.com/a/64932706
# Run command:
# docker run -it scoping:sans_enhsp /bin/bash
# Before running build, add ubuntu to the docker group by running `sudo usermod -aG docker ubuntu`, then exiting ssh, then sshing back in.
RUN apt-get update -y && echo "~~apt-get updated"
RUN apt-get install git jq cmake g++ make -y && echo "~~apt-get installed"
# Copy Scoping repo onto image
ENV SCOPING_DIR=/scoping_supplement/scoping
COPY ./ ${SCOPING_DIR}
# Install Conda
# From https://stackoverflow.com/a/57617879 (and other places)
RUN INSTALL_PATH=~/miniconda \
&& echo "~~~~~~Set miniconda INSTALL_PATH~~~~~~" \
&& wget --quiet https://repo.anaconda.com/miniconda/Miniconda3-py37_4.10.3-Linux-x86_64.sh -O ~/miniconda.sh\
&& echo "~~~~~~wgot miniconda installer"\
&& bash ~/miniconda.sh -fbp $INSTALL_PATH\
&& echo "~~~~~~Ran miniconda installer~~~~~~"\
&& PATH=$INSTALL_PATH/bin:$PATH\
&& echo "~~~~~~updated path to include conda~~~~~~"\
&& conda init bash\
&& echo "~~~~~~ran conda init bash~~~~~~"\
&& . ~/.bashrc\
&& echo "~~~~~~sourced .bashrc~~~~~~"\
&& conda create -n scoping python=3.7\
&& echo "~~~~~~created conda environment~~~~~~"\
&& conda activate scoping\
&& echo "~~~~~~activated conda environment~~~~~~"\
&& pip install pandas\
&& echo "~~~~~~installed pandas~~~~~~"\
&& cd ${SCOPING_DIR}\
&& echo "~~~~~~cd into scoping directory~~~~~~"\
&& pip install -e .\
&& echo "~~~~~~installed scoping repo~~~~~~"
# Install Fast Downward
WORKDIR /
RUN git clone https://github.com/aibasel/downward.git
WORKDIR /downward
RUN ./build.py
# Install ENHSP-2020 (TODO make this work!)
# ERROR : Failed to unshare root file system: Operation not permitted
# If we run `yes | enhsp-2020` from inside the container after running with the `--privileged` option, we instead get the following error:
# Original command: enhsp-2020
# FATAL: container creation failed: mount /etc/localtime->/etc/localtime error: while mounting /etc/localtime: while getting mount flags for /etc/localtime: while searching parent mount point entry for /etc/localtime: no parent mount point found
# If we run with `docker run --privileged -it -v /etc/localtime:/etc/localtime scoping:sans_enhsp /bin/bash` , then `conda activate scoping` then `yes | enhsp-2020`, it works!!
# This instalation is pretty fast. We could add the command to the startup script if we can't get it done in build.
# If we add ubuntu to the docker group then re-ssh in, we get this:
# Step 11/12 : RUN yes | enhsp-2020
# ---> Running in 09cc4ef58d87
# /bin/sh: 1: enhsp-2020: not found
RUN yes | enhsp-2020
WORKDIR ${SCOPING_DIR}