R Under development (unstable) (2024-10-19 r87247 ucrt) -- "Unsuffered Consequences" Copyright (C) 2024 The R Foundation for Statistical Computing Platform: x86_64-w64-mingw32/x64 R is free software and comes with ABSOLUTELY NO WARRANTY. You are welcome to redistribute it under certain conditions. Type 'license()' or 'licence()' for distribution details. R is a collaborative project with many contributors. Type 'contributors()' for more information and 'citation()' on how to cite R or R packages in publications. Type 'demo()' for some demos, 'help()' for on-line help, or 'help.start()' for an HTML browser interface to help. Type 'q()' to quit R. > ## 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() R Under development (unstable) (2024-10-19 r87247 ucrt) Platform: x86_64-w64-mingw32/x64 Running under: Windows Server 2022 x64 (build 20348) Matrix products: default locale: [1] LC_COLLATE=C LC_CTYPE=German_Germany.utf8 [3] LC_MONETARY=C LC_NUMERIC=C [5] LC_TIME=C time zone: Europe/Berlin tzcode source: internal attached base packages: [1] stats graphics grDevices utils datasets methods base other attached packages: [1] git2r_0.35.0 loaded via a namespace (and not attached): [1] compiler_4.5.0 > libgit2_version() $major [1] 1 $minor [1] 7 $rev [1] 2 > libgit2_features() $threads [1] TRUE $https [1] TRUE $ssh [1] FALSE > > > ## Create directories for repositories in tempdir > path_bare <- tempfile(pattern = "git2r-") > path_repo_1 <- tempfile(pattern = "git2r-") > path_repo_2 <- tempfile(pattern = "git2r-") > > dir.create(path_bare) > dir.create(path_repo_1) > dir.create(path_repo_2) > > ## Create bare repository > bare_repo <- init(path_bare, bare = TRUE) > > ## Clone to repo 1 > repo_1 <- clone(path_bare, path_repo_1) cloning into 'D:\temp\RtmpQlt2BE\git2r-322603cbd6b7c'... > config(repo_1, user.name = "Alice", user.email = "alice@example.org") > > ## Add changes to repo 1 and push to bare > writeLines("Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do", + con = file.path(path_repo_1, "test-1.txt")) > add(repo_1, "test-1.txt") > commit_1 <- commit(repo_1, "First commit message") > branch_name <- branches(repo_1)[[1]]$name > push(repo_1, "origin", paste0("refs/heads/", branch_name)) > > ## Clone to repo 2 > repo_2 <- clone(path_bare, path_repo_2) cloning into 'D:\temp\RtmpQlt2BE\git2r-3226027ac349'... > config(repo_2, user.name = "Bob", user.email = "bob@example.org") > > ## Add more changes to repo 1 and push to bare > writeLines(c("Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do", + "eiusmod tempor incididunt ut labore et dolore magna aliqua."), + con = file.path(path_repo_1, "test-1.txt")) > add(repo_1, "test-1.txt") > commit_2 <- commit(repo_1, "Second commit message") > push(repo_1, "origin", paste0("refs/heads/", branch_name)) > > ## Pull changes to repo_2 > pull(repo_2) [updated] e499c9f499..818dfe26c8 refs/remotes/origin/master Merge: Fast-forward > stopifnot(identical(length(commits(repo_2)), 2L)) > > ## Check remote url of repo_2 > stopifnot(identical( + branch_remote_url(branch_get_upstream(repository_head(repo_2))), + path_bare)) > > ## Unset remote remote tracking branch > branch_set_upstream(repository_head(repo_2), NULL) > stopifnot(is.null(branch_get_upstream(repository_head(repo_2)))) > tools::assertError(pull(repo_2)) > tools::assertError(branch_set_upstream(repository_head(repo_2), NULL)) > > ## Add more changes to repo 1 and push to bare > writeLines( + c("Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do", + "eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad", + "minim veniam, quis nostrud exercitation ullamco laboris nisi ut"), + con = file.path(path_repo_1, "test-1.txt")) > add(repo_1, "test-1.txt") > commit_3 <- commit(repo_1, "Third commit message") > push(repo_1) > > ## Set remote tracking branch > branch_set_upstream(repository_head(repo_2), + paste0("origin/", branch_name)) > stopifnot(identical( + branch_remote_url(branch_get_upstream(repository_head(repo_2))), + path_bare)) > > ## Pull changes to repo_2 > pull(repo_2) [updated] 818dfe26c8..7870d41177 refs/remotes/origin/master Merge: Fast-forward > stopifnot(identical(length(commits(repo_2)), 3L)) > > ## Check references in repo_1 and repo_2. Must clear the repo item > ## since the repositories have different paths. > stopifnot(identical(length(references(repo_1)), 2L)) > > ref_1 <- references(repo_1) > lapply(seq_len(length(ref_1)), function(i) { + ref_1[[i]]$repo <<- NULL + }) [[1]] NULL [[2]] NULL > > ref_2 <- references(repo_2) > lapply(seq_len(length(ref_2)), function(i) { + ref_2[[i]]$repo <<- NULL + }) [[1]] NULL [[2]] NULL [[3]] NULL > > name <- paste0("refs/heads/", branch_name) > stopifnot(identical(ref_1[[name]], ref_2[[name]])) > > name <- paste0("refs/remotes/", branch_name) > stopifnot(identical(ref_1[[name]], ref_2[[name]])) > > ref_1 <- references(repo_1)[[paste0("refs/heads/", branch_name)]] > stopifnot(identical(ref_1$name, paste0("refs/heads/", branch_name))) > stopifnot(identical(ref_1$type, 1L)) > stopifnot(identical(sha(ref_1), sha(commit_3))) > stopifnot(identical(ref_1$target, NA_character_)) > stopifnot(identical(ref_1$shorthand, branch_name)) > > ref_2 <- references(repo_1)[[paste0("refs/remotes/origin/", branch_name)]] > stopifnot(identical(ref_2$name, paste0("refs/remotes/origin/", branch_name))) > stopifnot(identical(ref_2$type, 1L)) > stopifnot(identical(sha(ref_2), sha(commit_3))) > stopifnot(identical(ref_2$target, NA_character_)) > stopifnot(identical(ref_2$shorthand, paste0("origin/", branch_name))) > > ## Check references with missing repo argument > wd <- setwd(path_repo_1) > stopifnot(identical(length(references()), 2L)) > if (!is.null(wd)) + setwd(wd) > > ## Cleanup > unlink(path_bare, recursive = TRUE) > unlink(path_repo_1, recursive = TRUE) > unlink(path_repo_2, recursive = TRUE) > > proc.time() user system elapsed 0.39 0.40 0.82