Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
G
GitLab Drupal CI
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container Registry
Model registry
Monitor
Service Desk
Analyze
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Docker
GitLab Drupal CI
Commits
3e4bc840
Commit
3e4bc840
authored
2 years ago
by
jurgenhaas
Browse files
Options
Downloads
Patches
Plain Diff
#19
Refactor merge script
parent
4ea53c33
No related branches found
Branches containing commit
Tags
v2.2.9
Tags containing commit
1 merge request
!37
Merging develop into main
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
bin/download
+3
-0
3 additions, 0 deletions
bin/download
bin/merge
+3
-115
3 additions, 115 deletions
bin/merge
with
6 additions
and
115 deletions
bin/download
+
3
−
0
View file @
3e4bc840
#!/bin/bash
set
-e
case
"
$1
"
in
db
)
task
=
CollectDatabase
;;
...
...
@@ -33,4 +35,5 @@ if [[ -d /tmp/${task}/ ]]; then
fi
else
echo
"Something went wrong"
exit
2
fi
This diff is collapsed.
Click to expand it.
bin/merge
+
3
−
115
View file @
3e4bc840
#!/bin/bash
export
DEBUG
=
no
function
gitlab
()
{
EXPECTED
=
$1
METHOD
=
$2
REQUEST
=
$3
shift
3
if
[[
"
${
DEBUG
}
"
==
"yes"
]]
;
then
echo
curl
--write-out
"
\n
HTTP-Code:%{http_code}"
-X
"
$METHOD
"
-s
-H
"Private-Token:
${
GITLAB_PRIVATE_TOKEN
}
"
"
${
GITLAB_URL
}
"
/api/v4/
"
$REQUEST
"
"
$@
"
fi
output
=
"
$(
curl
--write-out
"
\n
HTTP-Code:%{http_code}"
-X
"
$METHOD
"
-s
-H
"Private-Token:
${
GITLAB_PRIVATE_TOKEN
}
"
"
${
GITLAB_URL
}
"
/api/v4/
"
$REQUEST
"
"
$@
"
)
"
if
[[
"
${
DEBUG
}
"
==
"yes"
]]
;
then
echo
$output
fi
result
=
"
$(
echo
"
$output
"
|
grep
"{"
)
"
code
=
"
$(
echo
"
$output
"
|
grep
-m
1
"HTTP-Code:"
|
cut
-d
:
-f2
)
"
if
[[
$code
-eq
$EXPECTED
]]
;
then
return
fi
if
[[
"
${
DEBUG
}
"
==
"no"
]]
;
then
echo
$output
fi
echo
"
$METHOD
request to
$REQUEST
did not succeed! Responds with code
$code
instead of
$EXPECTED
"
exit
99
}
function
isNumeric
()
{
re
=
'^[0-9]+$'
if
[[
$1
=
~
$re
]]
;
then
return
0
fi
return
1
}
function
parseUrl
()
{
# extract the protocol
proto
=
"
$(
echo
"
$1
"
|
grep
:// |
sed
-e
's,^\(.*://\).*,\1,g'
)
"
# remove the protocol
url
=
"
${
1
/
$proto
/
}
"
# extract the user (if any)
user
=
"
$(
echo
"
$url
"
|
grep
@ |
cut
-d
@
-f1
)
"
# extract the host and port
hostport
=
"
$(
echo
"
${
url
/
$user
@/
}
"
|
cut
-d
/
-f1
)
"
# by request host without port
# shellcheck disable=SC2001
host
=
"
$(
echo
"
$hostport
"
|
sed
-e
's,:.*,,g'
)
"
# by request - try to extract the port
port
=
"
$(
echo
"
$hostport
"
|
sed
-e
's,^.*:,:,g'
-e
's,.*:\([0-9]*\).*,\1,g'
-e
's,[^0-9],,g'
)
"
# extract the path (if any)
path
=
"
$(
echo
"
$url
"
|
sed
-e
's,:,/,g'
|
grep
/ |
cut
-d
/
-f2-
)
"
}
set
-e
SOURCEBRANCH
=
$(
git rev-parse
--abbrev-ref
HEAD
)
if
[[
"x
$TARGETBRANCH
"
==
"x"
]]
;
then
...
...
@@ -67,59 +17,7 @@ if [[ "$TARGETBRANCH" == "$SOURCEBRANCH" ]]; then
echo
"Source and target branches must be different."
exit
2
fi
if
[[
-n
${
CI_SERVER_HOST
}
]]
;
then
GITLAB_URL
=
https://
$CI_SERVER_HOST
fi
if
[[
"x
${
GITLAB_URL
}
"
==
"x"
]]
;
then
echo
"Missing GITLAB_URL environment variable, should be set to e.g. https://gitlab.lakedrops.com"
exit
3
fi
if
[[
"x
${
GITLAB_PRIVATE_TOKEN
}
"
==
"x"
]]
;
then
echo
"Missing GITLAB_PRIVATE_TOKEN environment variable"
exit
4
fi
parseUrl
"
$GITLAB_URL
"
host1
=
$host
parseUrl
"
$(
git config remote.origin.url
)
"
host2
=
$host
if
[[
"
$host1
"
!=
"
$host2
"
]]
;
then
echo
"This repository doesn't match the provided GitLab instance"
exit
5
fi
if
[[
-n
${
CI_PROJECT_ID
}
]]
;
then
PRJID
=
$CI_PROJECT_ID
else
echo
"Find project ID from remote URL ..."
# shellcheck disable=SC2001
path
=
"
$(
echo
"
$path
"
|
sed
-e
's,\..*,,g'
)
"
gitlab 200 GET
"projects?search_namespaces=1&search=
$path
"
i
=
0
while
true
do
NAMESPACE
=
$(
echo
"
$result
"
| jq
-r
.[
$i
]
.
"path_with_namespace"
)
if
[[
"
$NAMESPACE
"
==
"
$path
"
]]
;
then
PRJID
=
$(
echo
"
$result
"
| jq
-r
.[
$i
]
.
"id"
)
if
[[
"a
${
PRJID
}
a"
==
"aa"
]]
;
then
echo
"No project found"
exit
6
fi
if
[[
$(
isNumeric
"
$PRJID
"
)
-eq
1
]]
;
then
echo
"Can not find project ID"
exit
6
fi
break
fi
if
[[
"a
${
NAMESPACE
}
a"
==
"aa"
]]
;
then
echo
"No project found"
exit
6
fi
((
i
=
i+1
))
done
fi
echo
"Create merge request ..."
# Create MR
TITLE
=
"Merging
$SOURCEBRANCH
into
$TARGETBRANCH
"
if
[[
"
${
SKIPCONFIGIMPORT
}
"
==
"yes"
]]
;
then
TITLE
=
"
${
TITLE
}
[SKIP_CONFIG_IMPORT]"
...
...
@@ -130,16 +28,6 @@ fi
if
[[
"
$1
"
==
"major"
]]
;
then
TITLE
=
"
${
TITLE
}
[MAJOR_VERSION]"
fi
gitlab 201 POST projects/
"
$PRJID
"
/merge_requests
--data
"source_branch=
$SOURCEBRANCH
"
--data
"target_branch=
$TARGETBRANCH
"
--data
"title=
$TITLE
"
MRID
=
$(
echo
"
$result
"
| jq
-r
.
"iid"
)
if
[[
$(
isNumeric
"
$MRID
"
)
-eq
1
]]
;
then
echo
"Can not create merge request"
exit
7
fi
echo
"Created MR at
$(
echo
"
$result
"
| jq
-r
.
"web_url"
)
"
echo
"Merge ..."
# Merge MR
sleep
5
gitlab 200 PUT projects/
"
$PRJID
"
/merge_requests/
"
$MRID
"
/merge
--data
"should_remove_source_branch=0"
echo
"Merged successfully!"
glab mr create
--fill
--yes
--source-branch
${
SOURCEBRANCH
}
--target-branch
${
TARGETBRANCH
}
--title
"
$TITLE
"
glab mr merge
--yes
${
TARGETBRANCH
}
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment