diff --git a/.circleci/config.yml b/.circleci/config.yml
index 5ac863b890861a98141a3b0b263e386c7f5b7be7..9d122c555eab634a67253d39303e4f758801e567 100644
--- a/.circleci/config.yml
+++ b/.circleci/config.yml
@@ -38,6 +38,13 @@ jobs:
           at: .
       - run: make test_integration
 
+  build:
+    <<: *defaults
+    steps:
+      - attach_workspace:
+          at: .
+      - run: make build
+
   release:
     <<: *defaults
     steps:
@@ -59,10 +66,10 @@ workflows:
   test_and_release:
     jobs:
       - checkout_code:
-          # Rather annoyingly we need this boilerplate on all transitive
+          # Rather annoyingly we need to include tags_filters on all transitive
           # dependencies if we want the deploy job to build against a version
           # tag.
-          # Also note jobs build against all branches by default
+          # In contract jobs build against all branches by default
           filters:
             <<: *tags_filters
       - test:
@@ -77,16 +84,22 @@ workflows:
           filters:
             <<: *tags_filters
 
+      - build:
+          requires:
+            - checkout_code
+          filters:
+            <<: *tags_filters
+
       - release:
           requires:
             - test
             - test_integration
+            - build
           filters:
+            # tags filters and branch filters are applied disjunctively, so we
+            # will still build tags not on develop (i.e. including tagged
+            # releases on master that we specifically want to build)
             <<: *tags_filters
             branches:
-              # Although we seem to exclude the master branch below, since
-              # matching on tags is independent we will still build tags that
-              # happen to point to a commit on master
-              # We push dev pre-release images for every commit on develop
               only: develop
 
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 6a78b5febf846c4d6823bc4a8b07e9784de5a677..59ce4188ec8e94f34d15eec5c5b8050a3ee7ea27 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,4 +1,7 @@
 # burrow changelog
+## v0.17.1
+Minor tweaks to docker build file
+
 ## v0.17.0
 This is a service release with some significant ethereum/solidity compatibility improvements and new logging features. It includes:
 
diff --git a/Dockerfile b/Dockerfile
index 033acdbb92b2a466c2261bebbd89331cdbdd2c8e..f4850d4866559b8a47d15588e818ff24e85a6569 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -5,7 +5,7 @@ MAINTAINER Monax <support@monax.io>
 RUN apk add --no-cache --update git
 RUN go get github.com/Masterminds/glide
 
-ENV REPO $GOPATH/src/github.com/hyperledger/burrow
+ARG REPO=$GOPATH/src/github.com/hyperledger/burrow
 COPY . $REPO
 WORKDIR $REPO
 RUN glide install
@@ -17,13 +17,9 @@ RUN go build --ldflags '-extldflags "-static"' -o bin/burrow-client ./client/cmd
 # This will be our base container image
 FROM alpine:3.6
 
-# There does not appear to be a way to share environment variables between stages
-ENV REPO /go/src/github.com/hyperledger/burrow
-
 ENV USER monax
 ENV MONAX_PATH /home/$USER/.monax
 RUN addgroup -g 101 -S $USER && adduser -S -D -u 1000 $USER $USER
-VOLUME $MONAX_PATH
 WORKDIR $MONAX_PATH
 USER $USER:$USER
 
diff --git a/Makefile b/Makefile
index 91b8dfc77c9d444fd19a8451e53cc025b19b8af4..260f0379c1e0c27e4b4d99b74e5502e329ec4244 100644
--- a/Makefile
+++ b/Makefile
@@ -121,7 +121,7 @@ build_race_client:
 
 # test burrow
 .PHONY: test
-test:
+test: check
 	@go test ${PACKAGES_NOVENDOR}
 
 .PHONY: test_integration
diff --git a/client/cmd/burrow-client.go b/client/cmd/burrow-client.go
index 77f746a38f4cee038f141e265f1c9ebbeacb0857..bb67c6ef4e92843c6d52dc557f0c5afa6a4452a8 100644
--- a/client/cmd/burrow-client.go
+++ b/client/cmd/burrow-client.go
@@ -35,7 +35,7 @@ var BurrowClientCmd = &cobra.Command{
 Made with <3 by Monax Industries.
 
 Complete documentation is available at https://monax.io/docs
-` + "\nVERSION:\n " + version.VERSION,
+` + "\nVERSION:\n " + version.GetSemanticVersionString(),
 	Run: func(cmd *cobra.Command, args []string) { cmd.Help() },
 }
 
diff --git a/cmd/burrow.go b/cmd/burrow.go
index a29f3e1fee9ace78eedd4f81eeed42f086834d3b..6fb484661b589a7a101064b972e1e30d0fad86dc 100644
--- a/cmd/burrow.go
+++ b/cmd/burrow.go
@@ -34,7 +34,7 @@ your needs.
 Made with <3 by Monax Industries.
 
 Complete documentation is available at https://monax.io/docs
-` + "\nVERSION:\n " + version.VERSION,
+` + "\nVERSION:\n " + version.GetSemanticVersionString(),
 	Run: func(cmd *cobra.Command, args []string) { cmd.Help() },
 }
 
diff --git a/event/events_test.go b/event/events_test.go
index 9f373f46ee8d30a5c08cdd63a41e9d7c7f02fc95..b9305d79e6de5d72ff02f459fcdd88502eda9dec 100644
--- a/event/events_test.go
+++ b/event/events_test.go
@@ -53,7 +53,7 @@ func TestMultiplexedEvents(t *testing.T) {
 		mutex2.Unlock()
 	})
 
-	time.Sleep(2 * mockInterval)
+	time.Sleep(4 * mockInterval)
 
 	err := emitter12.Unsubscribe("Sub12")
 	assert.NoError(t, err)
diff --git a/util/version/cmd/main.go b/util/version/cmd/main.go
index c5711e205dc6e67ac7c472afe3922e0d6714c892..3c7dd2ba5fc3a6a5069fa81f9d43c83511049390 100644
--- a/util/version/cmd/main.go
+++ b/util/version/cmd/main.go
@@ -22,5 +22,5 @@ import (
 
 // Print the Burrow version
 func main() {
-	fmt.Println(version.VERSION)
+	fmt.Println(version.GetSemanticVersionString())
 }
diff --git a/version/version.go b/version/version.go
index b92218bb3ac749a50cbdf4601a4455c61f0955bb..0ae7136c5103c6f24fddd349c651a4988d4624d7 100644
--- a/version/version.go
+++ b/version/version.go
@@ -32,7 +32,7 @@ const (
 	// Minor version component of the current release
 	versionMinor = 17
 	// Patch version component of the current release
-	versionPatch = 0
+	versionPatch = 1
 )
 
 var burrowVersion *VersionIdentifier
@@ -92,6 +92,13 @@ func (v *VersionIdentifier) GetMinorVersionString() string {
 		v.MinorVersion)
 }
 
+// Return the plain version string without the ClientIdentifier
+func GetSemanticVersionString() string { return burrowVersion.GetSemanticVersionString() }
+func (v *VersionIdentifier) GetSemanticVersionString() string {
+	return fmt.Sprintf("%d.%d.%d", v.MajorVersion,
+		v.MinorVersion, v.PatchVersion)
+}
+
 // note: similar remark applies here on the use of `int` over `uint8`
 // for the arguments as above for MakeVersionString()
 func MakeMinorVersionString(client string, major, minor, patch int) string {
@@ -125,8 +132,3 @@ func (version *VersionIdentifier) MatchesMinorVersion(
 		version.MajorVersion == referenceMajor &&
 		version.MinorVersion == referenceMinor
 }
-
-//------------------------------------------------------------------------------
-// util/version/cmd prints this when run and is used to by build_tool.sh to obtain
-// Burrow version
-const VERSION = "0.17.0"