KeiSeiKit-1.0/_primitives/_rust/kei-git-bitbucket/tests/wiremock.rs
Parfii-bot a4e667de10 KeiSeiKit-public — clean state
Single-commit clean baseline after security scrub of niche-tells,
project codenames, internal jargon, and contributor-email leaks.

Contents:
- 100 Rust crates (_primitives/_rust/)
- 37 agent manifests (_manifests/) + generated specs (_generated/)
- 67 user-invocable skills (skills/)
- 33 hooks (hooks/)
- Composition blocks (_blocks/)
- Documentation (docs/, README.md)
- TS adapter packages (_ts_packages/)
- Assembler (_assembler/)
- Roles (_roles/)
- Templates (_templates/)
- Forgejo CI (.forgejo/)

Author: Denis Parfionovich <info@greendragon.info>

License: see LICENSE.
2026-05-01 12:09:03 +08:00

110 lines
3.8 KiB
Rust

// SPDX-License-Identifier: Apache-2.0
// Copyright 2026 <author org>
//
//! wiremock integration tests for BitbucketClient + BitbucketBackend.
//!
//! Required surface (per Wave 5 spec):
//! - repo_exists 200
//! - repo_exists 404
//! - create_repo 200
//! - ensure_repo end-to-end (404 then POST)
use kei_git_bitbucket::{BitbucketBackend, BitbucketClient};
use kei_runtime_core::traits::git::{GitAuthKind, GitBackend, GitRemote};
use wiremock::matchers::{method, path};
use wiremock::{Mock, MockServer, ResponseTemplate};
#[tokio::test]
async fn repo_exists_200() {
let server = MockServer::start().await;
Mock::given(method("GET"))
.and(path("/repositories/ws/repo"))
.respond_with(ResponseTemplate::new(200).set_body_json(serde_json::json!({
"uuid": "{u}", "full_name": "ws/repo", "scm": "git", "is_private": true
})))
.expect(1)
.mount(&server)
.await;
let c = BitbucketClient::with_url("u", "p", server.uri()).unwrap();
assert!(c.repo_exists("ws", "repo").await.unwrap());
}
#[tokio::test]
async fn repo_exists_404() {
let server = MockServer::start().await;
Mock::given(method("GET"))
.and(path("/repositories/ws/missing"))
.respond_with(ResponseTemplate::new(404))
.expect(1)
.mount(&server)
.await;
let c = BitbucketClient::with_url("u", "p", server.uri()).unwrap();
assert!(!c.repo_exists("ws", "missing").await.unwrap());
}
#[tokio::test]
async fn create_repo_200() {
let server = MockServer::start().await;
Mock::given(method("POST"))
.and(path("/repositories/ws/new"))
.respond_with(ResponseTemplate::new(200).set_body_json(serde_json::json!({
"uuid": "{abc}", "full_name": "ws/new", "scm": "git", "is_private": true
})))
.expect(1)
.mount(&server)
.await;
let c = BitbucketClient::with_url("u", "p", server.uri()).unwrap();
let repo = c.create_repo("ws", "new").await.unwrap();
assert_eq!(repo.full_name, "ws/new");
assert_eq!(repo.scm, "git");
assert!(repo.is_private);
}
#[tokio::test]
async fn ensure_repo_creates_when_missing() {
let server = MockServer::start().await;
Mock::given(method("GET"))
.and(path("/repositories/ws/repo"))
.respond_with(ResponseTemplate::new(404))
.expect(1)
.mount(&server)
.await;
Mock::given(method("POST"))
.and(path("/repositories/ws/repo"))
.respond_with(ResponseTemplate::new(200).set_body_json(serde_json::json!({
"uuid": "{abc}", "full_name": "ws/repo",
"scm": "git", "is_private": true
})))
.expect(1)
.mount(&server)
.await;
let client = BitbucketClient::with_url("u", "p", server.uri()).unwrap();
let backend = BitbucketBackend::new(client, None).unwrap();
let remote = GitRemote {
url: format!("{}/ws/repo", server.uri()),
branch: "main".into(),
auth_kind: GitAuthKind::Pat,
};
backend.ensure_repo(&remote).await.expect("ensure_repo ok");
}
#[tokio::test]
async fn ensure_repo_no_op_when_present() {
let server = MockServer::start().await;
Mock::given(method("GET"))
.and(path("/repositories/ws/repo"))
.respond_with(ResponseTemplate::new(200).set_body_json(serde_json::json!({
"uuid": "{u}", "full_name": "ws/repo", "scm": "git", "is_private": true
})))
.expect(1)
.mount(&server)
.await;
let client = BitbucketClient::with_url("u", "p", server.uri()).unwrap();
let backend = BitbucketBackend::new(client, None).unwrap();
let remote = GitRemote {
url: format!("{}/ws/repo", server.uri()),
branch: "main".into(),
auth_kind: GitAuthKind::Pat,
};
backend.ensure_repo(&remote).await.expect("ensure_repo ok");
}