File: clone_bare.R

package info (click to toggle)
r-cran-git2r 0.36.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 1,968 kB
  • sloc: ansic: 8,299; sh: 4,104; makefile: 7
file content (82 lines) | stat: -rw-r--r-- 3,053 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
## 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)