Skip to content

Instantly share code, notes, and snippets.

@gtfierro
Last active July 15, 2021 16:20
Show Gist options
  • Save gtfierro/3c655904100d6abbb3af300127ba8e82 to your computer and use it in GitHub Desktop.
Save gtfierro/3c655904100d6abbb3af300127ba8e82 to your computer and use it in GitHub Desktop.
Haxall Docker
DOCKER_BUILDKIT=1 docker build -t haxalltest .
FROM openjdk:9
RUN apt-get update && apt-get install -y git build-essential wget vim expect
ADD script.exp /opt/script.exp
RUN wget --no-verbose -O /tmp/fantom.zip https://github.com/fantom-lang/fantom/releases/download/v1.0.76/fantom-1.0.76.zip
RUN unzip /tmp/fantom.zip
RUN mv /fantom-1.0.76 /fantom
RUN cd /fantom && bash adm/unixsetup
ENV PATH="/fantom/bin:${PATH}"
RUN wget --no-verbose -O /tmp/haystack-defs.zip https://github.com/Project-Haystack/haystack-defs/archive/refs/heads/master.zip
RUN unzip /tmp/haystack-defs.zip
RUN mv /haystack-defs-master /haystack-defs
RUN cd /haystack-defs && touch fan.props
RUN /haystack-defs/src/build.fan
RUN wget --no-verbose -O /tmp/haxall.zip https://github.com/haxall/haxall/archive/refs/heads/main.zip
RUN unzip /tmp/haxall.zip
RUN mv /haxall-main /haxall
ENV FAN_BUILD_JDKHOME=/docker-java-home/
WORKDIR /haxall
RUN echo "path=/haystack-defs" > fan.props
RUN src/build.fan
# initializes with user/pass = "test/testme"
RUN /opt/script.exp
ENTRYPOINT ["fan", "hx", "run", "test"]
#!/usr/bin/expect -f
#
# This Expect script was generated by autoexpect on Thu Jul 15 16:12:30 2021
# Expect and autoexpect were both written by Don Libes, NIST.
#
# Note that autoexpect does not guarantee a working script. It
# necessarily has to guess about certain things. Two reasons a script
# might fail are:
#
# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet,
# etc.) and devices discard or ignore keystrokes that arrive "too
# quickly" after prompts. If you find your new script hanging up at
# one spot, try adding a short sleep just before the previous send.
# Setting "force_conservative" to 1 (see below) makes Expect do this
# automatically - pausing briefly before sending each character. This
# pacifies every program I know of. The -c flag makes the script do
# this in the first place. The -C flag allows you to define a
# character to toggle this mode off and on.
set force_conservative 0 ;# set to 1 to force conservative mode even if
;# script wasn't run conservatively originally
if {$force_conservative} {
set send_slow {1 .1}
proc send {ignore arg} {
sleep .1
exp_send -s -- $arg
}
}
#
# 2) differing output - Some programs produce different output each time
# they run. The "date" command is an obvious example. Another is
# ftp, if it produces throughput statistics at the end of a file
# transfer. If this causes a problem, delete these patterns or replace
# them with wildcards. An alternative is to use the -p flag (for
# "prompt") which makes Expect only look for the last line of output
# (i.e., the prompt). The -P flag allows you to define a character to
# toggle this mode off and on.
#
# Read the man page for more info.
#
# -Don
set timeout -1
spawn fan hx init test
match_max 100000
expect -exact "\r
su username> "
send -- "test\r"
expect -exact "test\r
su password> "
send -- "testme\r"
expect -exact "\r
su password (confirm)> "
send -- "testme\r"
expect -exact "\r
http port \[8080\]> "
send -- "\r"
expect eof
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment