Current behavior
Getting spaceship_exec_vcs_info_precmd_hook:2: vcs_info: function definition file not found error when installing spaceship prompt in alpine container.
Used to work before...
_Dockerfile_
FROM alpine
# adding required packages
RUN apk add --no-cache git bash zsh
# Zsh config
RUN git clone git://github.com/robbyrussell/oh-my-zsh.git ~/.oh-my-zsh && \
cp ~/.oh-my-zsh/templates/zshrc.zsh-template ~/.zshrc
# Spaceship prompt setup https://github.com/denysdovhan/spaceship-prompt#oh-my-zsh
RUN ZSH_CUSTOM="/root/.oh-my-zsh/custom" && \
git clone git://github.com/denysdovhan/spaceship-prompt.git "$ZSH_CUSTOM/themes/spaceship-prompt" && \
ln -s "$ZSH_CUSTOM/themes/spaceship-prompt/spaceship.zsh-theme" "$ZSH_CUSTOM/themes/spaceship.zsh-theme"
# change theme to spaceship
RUN sed -i -E 's/ZSH_THEME="(.*?)"/ZSH_THEME="spaceship"/' ~/.zshrc
# setting work dir to root home folder
WORKDIR /root
_Steps to reproduce:_
Create above Dockerfile
Build docker file
docker build -t zsh .
Run container:
docker run --rm -it zsh /bin/zsh
Error should be displayed and will be displayed on subsequent command
➜ docker run --rm -it zsh /bin/zsh
spaceship_exec_vcs_info_precmd_hook:2: vcs_info: function definition file not found
root in ~
Expected behavior
Error should now be generated
.zshrc)# If you come from bash you might have to change your $PATH.
# export PATH=$HOME/bin:/usr/local/bin:$PATH
# Path to your oh-my-zsh installation.
export ZSH=$HOME/.oh-my-zsh
# Set name of the theme to load. Optionally, if you set this to "random"
# it'll load a random theme each time that oh-my-zsh is loaded.
# See https://github.com/robbyrussell/oh-my-zsh/wiki/Themes
ZSH_THEME="spaceship"
# Set list of themes to load
# Setting this variable when ZSH_THEME=random
# cause zsh load theme from this variable instead of
# looking in ~/.oh-my-zsh/themes/
# An empty array have no effect
# ZSH_THEME_RANDOM_CANDIDATES=( "robbyrussell" "agnoster" )
# Uncomment the following line to use case-sensitive completion.
# CASE_SENSITIVE="true"
# Uncomment the following line to use hyphen-insensitive completion. Case
# sensitive completion must be off. _ and - will be interchangeable.
# HYPHEN_INSENSITIVE="true"
# Uncomment the following line to disable bi-weekly auto-update checks.
# DISABLE_AUTO_UPDATE="true"
# Uncomment the following line to change how often to auto-update (in days).
# export UPDATE_ZSH_DAYS=13
# Uncomment the following line to disable colors in ls.
# DISABLE_LS_COLORS="true"
# Uncomment the following line to disable auto-setting terminal title.
# DISABLE_AUTO_TITLE="true"
# Uncomment the following line to enable command auto-correction.
# ENABLE_CORRECTION="true"
# Uncomment the following line to display red dots whilst waiting for completion.
# COMPLETION_WAITING_DOTS="true"
# Uncomment the following line if you want to disable marking untracked files
# under VCS as dirty. This makes repository status check for large repositories
# much, much faster.
# DISABLE_UNTRACKED_FILES_DIRTY="true"
# Uncomment the following line if you want to change the command execution time
# stamp shown in the history command output.
# The optional three formats: "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd"
# HIST_STAMPS="mm/dd/yyyy"
# Would you like to use another custom folder than $ZSH/custom?
# ZSH_CUSTOM=/path/to/new-custom-folder
# Which plugins would you like to load? (plugins can be found in ~/.oh-my-zsh/plugins/*)
# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/
# Example format: plugins=(rails git textmate ruby lighthouse)
# Add wisely, as too many plugins slow down shell startup.
plugins=(
git
)
source $ZSH/oh-my-zsh.sh
# User configuration
# export MANPATH="/usr/local/man:$MANPATH"
# You may need to manually set your language environment
# export LANG=en_US.UTF-8
# Preferred editor for local and remote sessions
# if [[ -n $SSH_CONNECTION ]]; then
# export EDITOR='vim'
# else
# export EDITOR='mvim'
# fi
# Compilation flags
# export ARCHFLAGS="-arch x86_64"
# ssh
# export SSH_KEY_PATH="~/.ssh/rsa_id"
# Set personal aliases, overriding those provided by oh-my-zsh libs,
# plugins, and themes. Aliases can be placed here, though oh-my-zsh
# users are encouraged to define aliases within the ZSH_CUSTOM folder.
# For a full list of active aliases, run `alias`.
#
# Example aliases
# alias zshconfig="mate ~/.zshrc"
# alias ohmyzsh="mate ~/.oh-my-zsh"
Spaceship version: 3.4.1 (use echo $SPACESHIP_VERSION)
Zsh version: zsh 5.4.2 (x86_64-alpine-linux-musl)
Zsh framework:
Zsh plugin manager: oh-my-zsh
Terminal emulator: NA
Operating system: linux alpine container
Provide a screenshot that shows your issue.

Possible solution
Am I missing any install steps or components?
Thank you @choovick for the detailed issue filing, Spot on for reproducing the issue :smile:
We depend on vcs_info module for git section. Seems like vcs_info is packaged separately on alpine. apk add zsh-vcs loads the required module.

@salmanulfarzy you sir amazing! that did it! lightweight alpine packages... :)
added zsh-vcs package to my docker file.
Closing
Most helpful comment
Thank you @choovick for the detailed issue filing, Spot on for reproducing the issue :smile:
We depend on
vcs_infomodule forgitsection. Seems likevcs_infois packaged separately on alpine.apk add zsh-vcsloads the required module.