Skip to content

catks/gitserver-http

 
 

Repository files navigation

gitserver-http CI

A http git server for testing

Usage

To run a git server without any repositories configured in advance but allowing them to be saved into ./repositories:

docker run \
  -d  \                                 # daemonize
  -v `pwd`/repositories:/var/lib/git \  # mount the volume
  -p "8080:80" \                        # expose the port
  catks/gitserver-http:0.1.0

Now, initialize a bare repository:

cd repositories
git init --bare myrepo.git

and then, just clone it somewhere else:

cd /tmp
git clone http://localhost:8080/myrepo.git
cd myrepo

Pre-Initialization

Git servers work with bare repositories. This image provides the utility of initializing some pre-configured repositories in advance. Just add them to /var/lib/initial and then run the container. For instance, having the tree:

.
└── initial
    └── repo1
        └── file.txt

and then executing

docker run \
  -d  \                                 # deamonize
  -v `pwd`/initial:/var/lib/initial \   # mount the initial volume
  -p "8080:80" \                        # expose the port
  catks/gitserver-http:0.1.0            # start git server and init repositories

will allow you to skip the git init --bare step and start with the repositories pre-"installed" there:

git clone http://localhost/repo1.git
cd repo1 && ls
# file.txt

Example

to run the example:

make example

This will create a git server http service on :80. Now you can clone the sample repository:

git clone http://localhost:8080/repo1.git

About

git-http-backend with repository initialization

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 84.3%
  • Dockerfile 9.4%
  • Makefile 6.3%