gerrit-rust
is a console client for gerrit written in rust. This is a rust
learner project. Have patience with me :-)
I'm happy about every PR, but I will ask questions about changes to learn from
your knowledge.
Some design considarations here.
[x] 0.1.0 Use a config file .ggr.config
in TOML format
baseurl
: base url with schema (http)port
: used portappendix
: for gerrit server under a subpath (not tested)username
: username for login
password
: password for loginroot
: true if this is the uppermost project of all repositories
underneath
Consider to configure via config file or put all settings into
as entries in .git/config
.
The values are same for config file and git-config approach. For the
git-config we use ggr-
as a prefix.
provide a configuration frontend
ggr config set baseurl 'http://localhost'
: set new baseurl
ggr config unset -C project1 root
: remove root
in project1
repositoryggr config set root
: set root for current repositoryggr config list
: list all options
ggr config generate --base <...> ...
: generates
a .ggr.config
filemanage of topics over more than one repository (git submodules like)
[x] 0.1.0 ggr topic create <BRANCHNAME> [-r sub:rev]
TBD Create branch at main folder and specified subfolders. If a branch
with same name exists it isn't touched. rev
is the reference where
branch should created Defaults to orign/master
. For base folder use
-r .
.
-R
option to create branch on base and all
subrepositories.[x] 0.1.0 ggr topic forget <BRANCHNAME> [-R]
TBD Delete a branch at mainfolder and and with -R
in all subfolders.
-s
in conjunction with -R
to remove all branches
recursive which have no commit and the repositories are clean. Warn
unclean repositories/branches.[ ] ggr topic list -s
TBD List all development branches and the repositories. With -s
it
includes the commits in the branch like git submodule summary
.
[ ] ggr topic checkout <BRANCHNAME>
TBD checkout a branch.
[ ] ggr topic push [-b] [<BRANCHNAME>]
TBD Push changes to gerrit. Without -b
its pushed to gerrit. With
option -b
its pushed to a build server. Without branchname the
current branch is pushed.
[ ] ggr topic pull <BRANCHNAME>
TBD Pulls a branch.
[ ] ggr topic reviewer [<BRANCHNAME>] [-r <MAIL>] [-c <MAIL>] [-t <MAIL>]
TBD Add reviewer (-r
), CC: (-c
) or TO: (-t
) at topic push time.
The information is put to branch config like config.BRANCHNAME.ggr-re MAIL
.
Config lineentries start with ggr-[cc/to/re]. Without any options the
current reviewer/to/cc showed for current branch. Without BRANCHNAME te
current branch is taken.
Other Ideas
[ ] 0.1.0 ggr changes query <QUERY>
TBD: query a searchstring to gerrit server.
--fields
to get only needed fields back. As the current
solution prints only some fields. A talk on #rust-de suggested some
solutions how to handle the input string field names with the
ChangesInfo struct. Eg: https://is.gd/PADslX.Examples:
ggr query changes status:open is:watched n:2
: querry open changes
which are watched.[ ] create a helper script for setup of development environment
docker pull docker.io/fabric8/gerrit:latest
[ ] ggr stat [-F <date>] [-T <data>]
TBD some statistics like opened and closed review since a week or
between a timespan. via iso-8601 like date -Is
.
Examples:
ggr stat -F 1w
: last week to nowggr stat -F 2015-12-31 -T 2016-02-01
: from 01.01.2016T00:00 till 01.02.2016T23:59:59ggr stat -F 2016-01-01
: from 02.01.2016T00:00 till nowggr stat -T 2016-02-01
: from begin of gerrit usage till 01.02.2016T23:59:59reviewer per commit (TBD)
reviewer per repository (TBD)
status of branches (TBD)
shows status of a branch (remote and local like git remote show ...
ggr status [<BRANCHNAME>]
Support for .repo
folder
Consider to use https://github.com/gsingh93/trace
Consider to use https://github.com/ticki/termion
Document gerritlib::call
module
This creates a dockercontainer which is connectable via http://localhost:8080.
The server is setup for development and all accounts can do all things.
It generate or use a DOCKER-FOR-GERRIT
folder with all settings, repositories
and ssh-keys.
text
docker run --rm -it -p 0.0.0.0:8080:8080 -p 127.0.0.1:29418:29418 \
-e AUTH_TYPE='OpenID' \
-e GERRIT_PUBLIC_KEYS_PATH='/home/gerrit/ssh-keys' \
-v ${PWD}/DOCKER-FOR-GERRIT/ssh-keys:/home/gerrit/ssh-keys \
-v ${PWD}/DOCKER-FOR-GERRIT/site:/home/gerrit/site \
--name gerrit docker.io/fabric8/gerrit:latest
ggr topic create testfeature -F p1:origin/master -F p2
p3
needs changes toocd p3 ; ggr topic create testfeature
ggr topic push -b testfeature
ggr topic push testfeature
With this we can handle the rest api ...
text
curl -x GET 'http://localhost:8080/projects/?&b=master'
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.