R Under development (unstable) (2023-11-25 r85635 ucrt) -- "Unsuffered Consequences" Copyright (C) 2023 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) (2023-11-25 r85635 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.33.0 loaded via a namespace (and not attached): [1] compiler_4.4.0 > libgit2_version() $major [1] 1 $minor [1] 7 $rev [1] 1 > libgit2_features() $threads [1] TRUE $https [1] TRUE $ssh [1] FALSE > > > ## Create 2 directories 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 repositories > bare_repo <- init(path_bare, bare = TRUE) > repo_1 <- clone(path_bare, path_repo_1) cloning into 'D:\temp\Rtmpk7B9P1\git2r-1008830b3112a'... > repo_2 <- clone(path_bare, path_repo_2) cloning into 'D:\temp\Rtmpk7B9P1\git2r-100885a7060d'... > > ## Config repositories > config(repo_1, user.name = "Alice", user.email = "alice@example.org") > config(repo_2, user.name = "Bob", user.email = "bob@example.org") > > ## Add changes to repo 1 > writeLines("Hello world", con = file.path(path_repo_1, "test.txt")) > add(repo_1, "test.txt") > commit_1 <- commit(repo_1, "Commit message") > branch_name <- branches(repo_1)[[1]]$name > > ## Push changes from repo 1 to origin > push(repo_1, "origin", paste0("refs/heads/", branch_name)) > > ## 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)) > > ## Fetch > fetch(repo_2, "origin") [new] e5c4abd6ce39ee199fd1 refs/remotes/origin/master > fh <- fetch_heads(repo_2)[[1]] > stopifnot(identical(sha(fh), fh$sha)) > > ## Test show method of non-empty repository where head is null > show(repo_2) Local: D:/temp/Rtmpk7B9P1/git2r-100885a7060d Head: nothing commited (yet) > > ## Check that 'git2r_arg_check_credentials' raise error > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", + 3, "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", repo_1, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- cred_env(c("username", "username"), "password") > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- cred_env("username", c("password", "passowrd")) > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- cred_user_pass(c("username", "username"), "password") > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- cred_user_pass("username", c("password", "passowrd")) > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- cred_token(c("GITHUB_PAT", "GITHUB_PAT")) > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- structure(list(publickey = c("id_rsa.pub", "id_rsa.pub"), + privatekey = "id_rsa", + passphrase = character(0)), + class = "cred_ssh_key") > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- structure(list(publickey = "id_rsa.pub", + privatekey = c("id_rsa", "id_rsa"), + passphrase = character(0)), + class = "cred_ssh_key") > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- structure(list(publickey = "id_rsa.pub", + privatekey = "id_rsa", + passphrase = NA_character_), + class = "cred_ssh_key") > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > credentials <- structure(list(publickey = "id_rsa.pub", + privatekey = "id_rsa", + passphrase = c("passphrase", "passphrase")), + class = "cred_ssh_key") > res <- tools::assertError( + .Call(git2r:::git2r_remote_fetch, repo_1, "origin", credentials, + "fetch", FALSE, NULL)) > stopifnot(length(grep("'credentials' must be an S3 class with credentials", + res[[1]]$message)) > 0) > > ## Cleanup > unlink(path_bare, recursive = TRUE) > unlink(path_repo_1, recursive = TRUE) > unlink(path_repo_2, recursive = TRUE) > > proc.time() user system elapsed 0.20 0.07 0.28