From Fedora Project Wiki

No edit summary
(Accurate list of supported VCSes and remove h1)
Line 1: Line 1:
{{header|infra}}
{{header|infra}}


= Setup a New Mercurial, GIT, Bazaar, or SVN Repository =
Fedora hosted has public repositories for git, bazaar, mercurial, and subversion.  These are instructions for adding a new project to one of them.


Since Fedora already has public git and mercurial servers it's pretty easy to add a new project to them.
{{admon/note|Monotone support has been discontinued due to both lack of a sysadmin to maintain it and lack of projects wanting to use it.}}


== Mercurial Repository ==
== Mercurial Repository ==

Revision as of 23:59, 6 March 2009


Fedora hosted has public repositories for git, bazaar, mercurial, and subversion. These are instructions for adding a new project to one of them.

Note.png
Monotone support has been discontinued due to both lack of a sysadmin to maintain it and lack of projects wanting to use it.

Mercurial Repository

You'll need to know three things in order to start the mercurial repository.

  1. PROJECTNAME -- what the project wants to be called.
  2. OLDURL -- how to access the project's current sourcecode in their mercurial repository.
  3. PROJECTGROUP -- the group setup in the account system for readwrite access to the repository.

The Mercurial repository lives on the hosted server. Access it by logging into hosted1 Then follow these steps:

$ cd /hg
$ sudo hg clone -U $OLDURL $PROJECTNAME (or sudo mkdir $PROJECTNAME; cd $PROJECTNAME; sudo hg init)
$ sudo find $PROJECTNAME -type d -exec chmod g+s \{\} \;
$ sudo chmod -R g+w $PROJECTNAME
$ sudo chown -R root:$PROJECTGROUP $PROJECTNAME

This should setup all the files needed for the repository.

Commit Mail

The Mercurial Notify extension can be used to send out email when commits are pushed to a Mecurial repository. To enable notifications, create the file /hg/$PROJECTNAME/.hg/hgrc:

[extensions] 
hgext.notify =

[hooks] 
changegroup.notify = python:hgext.notify.hook

[email] 
from = admin@fedoraproject.org

[smtp] 
host = localhost

[web] 
baseurl = http://hg.fedoraproject.org/hg

[notify] 
sources = serve push pull bundle
test = False
config = /hg/$PROJECTNAME/.hg/subscriptions
maxdiff = -1

And the file /hg/$PROJECTNAME/.hg/subscriptions:

[usersubs] 

user@host = *

[reposubs] 

Git Repository

You'll need to know three things in order to start the git repository.

  1. PROJECTNAME -- what the project wants to be called.
  2. OLDURL -- how to access the project's current source code in their git repository.
  3. PROJECTGROUP -- the group setup in the account system for write access to the repository.
  4. COMMITLIST -- comma-separated list of email addresses for commits (optional)
  5. DESCRIPTION -- description of the project (optional)
  6. PROJECTOWNER -- the FAS username of the project owner

The git repository lives on the hosted server. Access it by logging into hosted1 Then follow these steps:

$ cd /git
$ sudo git clone --bare $OLDURL $PROJECTNAME.git (or sudo mkdir $PROJECTNAME.git; pushd $PROJECTNAME.git; GIT_DIR=. sudo git init-db --shared=true; add a file; popd)
$ sudo rm $PROJECTNAME.git/hooks/post-update
$ sudo ln -s /usr/bin/git-update-server-info $PROJECTNAME.git/hooks/post-update
$ cd $PROJECTNAME.git; GIT_DIR=. sudo git-update-server-info; cd ../
$ sudo find $PROJECTNAME.git -type d -exec chmod g+s \{\} \;
$ sudo chmod -R g+w $PROJECTNAME.git
$ sudo chown -R $PROJECTOWNER:$PROJECTGROUP $PROJECTNAME.git

If you don't have any files in the repository then git will balk about it. Do this on hosted1 to make your repo work:

$ cd
$ git clone /git/$PROJECTNAME.git
$ cd $PROJECTNAME
$ touch file
$ git add file
$ git commit
$ git push /git/$PROJECTNAME.git/ master

This should setup all the files needed for the repository.

Commit Mail

If they want commit mail, then there are a couple of additional steps.

$ echo $COMMITLIST > commit-list
$ echo $DESCRIPTION > description
$ ln -s /usr/bin/fedora-git-commit-mail-hook hooks/update

Bazaar Repository

You'll need to know three things in order to start a bazaar repository.

  1. PROJECTNAME -- what the project wants to be called.
  2. OLDBRANCHURL -- how to access the project's current sourcecode in their previous bazaar repository. Note that a project may have multiple branches that they want to import. Each branch will have a separate URL. (The project can import the new branches after the repository is created if they want.)
  3. PROJECTGROUP -- the group setup in the account system for readwrite access to the repository.

The bzr repository lives on the hosted server. Access it by logging into hosted1 then follow these steps:

The first stage is to create the Bazaar repository.

$ cd /srv/bzr/
$ # This creates a Bazaar repository which has shared storage between branches
$ sudo bzr init-repo $PROJECTNAME --no-trees
$ cd $PROJECTNAME
$ sudo bzr branch $OLDURL
$ sudo bzr branch $OLDURL2
$ # [...] 
$ sudo bzr branch $OLDURLN
$ cd ..
$ sudo find $PROJECTNAME -type d -exec chmod g+s \{\} \;
$ sudo chmod -R g+w $PROJECTNAME
$ sudo chown -R root:$PROJECTGROUP $PROJECTNAME

This should be all that is needed. To checkout run:

bzr init-repo $MYLOCALPROJECTREPO
cd $MYLOCALPROJECTREPO
bzr branch bzr+ssh://bzr.fedorahosted.org/bzr/$PROJECTNAME/$BRANCHNAME
bzr branch bzr://bzr.fedorahosted.org/bzr/$PROJECTNAME/$BRANCHNAME/

Note: If the end user checks out a branch without creating their own repository they will need to create a local working tree by doing the following:

cd $BRANCHNAME
bzr checkout --lightweight

SVN Repository

You'll need to know two things in order to start a svn repository.

  1. PROJECTNAME -- what the project wants to be called.
  2. PROJECTGROUP -- The Fedora account system group with read-write access.

SVN lives on the hosted server. Access it by logging into hosted1. Then run the following steps:

$ cd /svn/
$ sudo svnadmin create $PROJECTNAME
$ sudo chgrp -R $GROUPNAME $PROJECTNAME
$ sudo chmod -R g+w $PROJECTNAME
$ find $PROJECTNAME -type d | sudo xargs chmod g+s

This should be all that is needed. To checkout run:

svn co svn+ssh://svn.fedorahosted.org/svn/$PROJECTNAME


Monotone Repository *UNFINISHED DRAFT*

You'll need to know these things in order to start the Monotone repository:

  1. PROJECTNAME -- what the project wants to be called.
  2. PROJECTGROUP -- the group setup in the account system for write access to the repository.

The Monotone repository lives on the hosted server. Access it by logging into hosted1. Then follow these steps:

$ cd /mtn/
$ sudo mkdir -m a=rx,g+ws,u+w $PROJECTNAME
$ sudo mtn --db $PROJECTNAME/db.mtn db init
$ sudo chgrp -R $PROJECTGROUP $PROJECTNAME
$ sudo chmod -R g+w $PROJECTNAME

This should be all that is needed. Now you have an empty database. Anyone in the $PROJECTGROUP group can populate it using:

mtn sync ssh://mtn.fedorahosted.org/mtn/hosted/$PROJECTNAME/db.mtn