File: push.R

package info (click to toggle)
r-cran-git2r 0.35.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,956 kB
  • sloc: ansic: 8,203; sh: 4,104; makefile: 7
file content (118 lines) | stat: -rw-r--r-- 4,668 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
## git2r, R bindings to the libgit2 library.
## Copyright (C) 2013-2023 The git2r contributors
##
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License, version 2,
## as published by the Free Software Foundation.
##
## git2r is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
## GNU General Public License for more details.
##
## You should have received a copy of the GNU General Public License along
## with this program; if not, write to the Free Software Foundation, Inc.,
## 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

library(git2r)

## For debugging
sessionInfo()
libgit2_version()
libgit2_features()


## Create 2 directories in tempdir
path_bare <- tempfile(pattern = "git2r-")
path_repo <- tempfile(pattern = "git2r-")

dir.create(path_bare)
dir.create(path_repo)

## Create repositories
bare_repo <- init(path_bare, bare = TRUE)
repo <- clone(path_bare, path_repo)

## Check the repositores
stopifnot(identical(is_bare(bare_repo), TRUE))
stopifnot(identical(is_bare(repo), FALSE))

## Config repositories
config(repo, user.name = "Alice", user.email = "alice@example.org")

## Add changes to repo
writeLines("Hello world", con = file.path(path_repo, "test.txt"))
add(repo, "test.txt")
commit_1 <- commit(repo, "Commit message")
branch_name <- branches(repo)[[1]]$name

## Check commit
stopifnot(identical(commit_1$author$name, "Alice"))
stopifnot(identical(commit_1$author$email, "alice@example.org"))
stopifnot(identical(length(commits(repo)), 1L))
stopifnot(identical(commits(repo)[[1]]$author$name, "Alice"))
stopifnot(identical(commits(repo)[[1]]$author$email, "alice@example.org"))

## Check push arguments
tools::assertError(push(repo, character(0), paste0("refs/heads/", branch_name)))
tools::assertError(push(repo, NA_character_, paste0("refs/heads/", branch_name)))
tools::assertError(push(repo, c("origin", "origin"), paste0("refs/heads/", branch_name)))
tools::assertError(push(repo, "origin"))
tools::assertError(push(repo, name = "origin"))
push(repo, "origin", character(0))
push(repo, "origin", NA_character_)
push(repo, "origin", c(NA_character_, NA_character_))
stopifnot(identical(reflog(repo, paste0("refs/remotes/origin/", branch_name)),
                    structure(list(), class = "git_reflog")))

## No tracking branch assigned to master
tools::assertError(push(branches(repo)[[1]]))

## Push changes from repo to origin
push(repo, "origin", paste0("refs/heads/", branch_name))
r <- reflog(repo, paste0("refs/remotes/origin/", branch_name))
stopifnot(identical(length(r), 1L))
r <- r[[1]]
stopifnot(identical(sha(r), sha(commit_1)))
stopifnot(identical(r$message, "update by push"))
stopifnot(identical(r$index, 0L))
stopifnot(identical(r$committer$name, "Alice"))
stopifnot(identical(r$committer$email, "alice@example.org"))
stopifnot(identical(r$refname, paste0("refs/remotes/origin/", branch_name)))
stopifnot(identical(r$repo$path, repo$path))
push(branches(repo)[[1]])

## Check result in bare repository
stopifnot(identical(length(commits(bare_repo)), 1L))
bare_commit_1 <- commits(bare_repo)[[1]]
stopifnot(identical(sha(commit_1), sha(bare_commit_1)))
stopifnot(identical(commit_1$author, bare_commit_1$author))
stopifnot(identical(commit_1$committer, bare_commit_1$committer))
stopifnot(identical(commit_1$summary, bare_commit_1$summary))
stopifnot(identical(commit_1$message, bare_commit_1$message))
stopifnot(!identical(commit_1$repo, bare_commit_1$repo))

## Add changes to repo and push head
writeLines(c("Hello world", "HELLO WORLD"),
           con = file.path(path_repo, "test.txt"))
add(repo, "test.txt")
commit_2 <- commit(repo, "Commit message 2")
push(repo)
bare_commit_2 <- lookup(bare_repo, sha(commit_2))
stopifnot(identical(sha(commit_2), sha(bare_commit_2)))
stopifnot(identical(commit_2$author, bare_commit_2$author))
stopifnot(identical(commit_2$committer, bare_commit_2$committer))
stopifnot(identical(commit_2$summary, bare_commit_2$summary))
stopifnot(identical(commit_2$message, bare_commit_2$message))
stopifnot(!identical(commit_2$repo, bare_commit_2$repo))

## Check 'set_upstream'
branch_set_upstream(repository_head(repo), NULL)
push(repo, "origin", paste0("refs/heads/", branch_name))
stopifnot(is.null(branch_get_upstream(repository_head(repo))))
push(repo, "origin", paste0("refs/heads/", branch_name), set_upstream = TRUE)
stopifnot(!is.null(branch_get_upstream(repository_head(repo))))

## Cleanup
unlink(path_bare, recursive = TRUE)
unlink(path_repo, recursive = TRUE)