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
|
## 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)
## Initialize a repository
repo <- init(path_repo)
config(repo, user.name = "Alice", user.email = "alice@example.org")
## Add commit to repo
writeLines("Hello world", con = file.path(path_repo, "test.txt"))
add(repo, "test.txt")
commit_1 <- commit(repo, "Commit message")
## Check bare argument
tools::assertError(clone(path_repo, path_bare, bare = c(TRUE, TRUE)))
tools::assertError(clone(path_repo, path_bare, bare = 1))
tools::assertError(clone(path_repo, path_bare, bare = 1L))
tools::assertError(clone(path_repo, path_bare, bare = "test"))
## Clone repo to bare repository
bare_repo <- clone(path_repo, path_bare, bare = TRUE)
## Check the repositores
stopifnot(identical(is_bare(bare_repo), TRUE))
stopifnot(identical(is_bare(repo), FALSE))
## 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))
if (identical(Sys.getenv("NOT_CRAN"), "true")) {
## Minimal check: test that calling `clone` with `proxy=TRUE` doesn't crash
test_path_proxy <- tempfile(pattern = "git2r-clone-proxy-")
dir.create(test_path_proxy)
message("Testing clone() with proxy=TRUE (auto-detect)")
tryCatch({
proxy_repo <- clone(path_repo, test_path_proxy, proxy = TRUE)
# If we get here without error, the parameter was accepted;
# further checks might be minimal if there's no real proxy in use.
stopifnot(identical(is_bare(proxy_repo), FALSE))
stopifnot(length(commits(proxy_repo)) == 1L)
}, error = function(e) {
message("clone() with proxy=TRUE failed as expected if no actual proxy is set: ", e$message)
})
}
## Cleanup
unlink(path_bare, recursive = TRUE)
unlink(path_repo, recursive = TRUE)
|