[VOL-5063] - Fix stale voltctl binary install by docker.

docker/Dockerfile.voltctl
-------------------------
  o voltctl v1.6.1 installed by hardcoded path.
    - v1.8.3 released, v1.9.1 latest available (release pending).
  o Download into a temp file to avoid contention or access problems.
  o Split download and install into two distinct steps:
    - Helps create a tiny window for installation.
    - Binary corrupt/unusable while downloading.
  o Plenty of comments added.
  o Long term revisit this logic, branch==master should retrieve/install
    latest tagged release binary.  Release cycle needs to retrieve a
    frozen binary but only on the release branch/tag.

Change-Id: I6f301b934b67dcd3061c7b48386d016ab62e8a82
diff --git a/docker/Dockerfile.voltctl b/docker/Dockerfile.voltctl
index a394938..9931b9f 100644
--- a/docker/Dockerfile.voltctl
+++ b/docker/Dockerfile.voltctl
@@ -15,7 +15,47 @@
 FROM busybox:1.31.1-glibc
 
 RUN mkdir -p /usr/bin
-RUN wget -O - https://github.com/opencord/voltctl/releases/download/v1.6.1/voltctl-1.6.1-linux-amd64 > /usr/bin/voltctl
+
+# -------------------------------------------------------------------
+# [VOL-5063] - branch==master install latest (tag ?!?)
+#    else install release(d) version.
+# -------------------------------------------------------------------
+# https://api.github.com/repos/opencord/voltctl/releases/latest
+#   - offers voltctl/releases/download/1.8.45 as released
+# https://github.com/opencord/voltctl/releases
+#   - offers v1.9.1 (latest released via build + tagging).
+# -------------------------------------------------------------------
+# RUN wget -O - https://github.com/opencord/voltctl/releases/download/v1.9.1/voltctl-1.9.1-linux-amd64 
+
+# https://github.com/opencord/voltctl/releases/download/untagged-cd611c39178f25b95a87/voltctl-1.9.1-linux-amd64
+
+RUN wget -q\
+  -O /usr/bin/voltctl.tmp\
+  https://github.com/opencord/voltctl/releases/download/v1.8.45/voltctl-1.8.45-linux-amd64
+
+## -----------------------------------------------------
+## Maintain a tiny window for rename to avoid contention
+##   - Validate download by displaying version
+##     - --version not supported by wget binary
+##   - Detection and error recovery possible if release
+##     binary corrupt or mia but potential for stale
+##     command version to silently persist is a larger
+##     testing issue so explicitly overwrite.
+## -----------------------------------------------------
+RUN chmod a+x /usr/bin/voltctl.tmp && sync
+# RUN /usr/bin/voltctl.tmp --version
 COPY volt.config /root/.volt/config
-RUN chmod a+x /usr/bin/voltctl && sync && voltctl completion bash >> /root/.bashrc
+RUN mv -vf /usr/bin/voltctl.tmp /usr/bin/voltctl
+RUN /usr/bin/voltctl completion bash >> /root/.bashrc
+
+## -----------------------------------------------------------------------
+## Infinite loop -- huh(?!?)
+## Interrogate voltctl startup for status to avoid potential for
+## container accumulation when downstream container shutdown fails.
+## -----------------------------------------------------------------------
+## If sleep is intended to keep the container alive for downstream tasks
+## use handshakes and/or timeouts to avoid long term, idle, resource retention
+## -----------------------------------------------------------------------
 CMD ["sh", "-c", "sleep infinity"]
+
+# [EOF]