Skip to content

Commit

Permalink
Finish testing the unit tests - put the additional integration tests …
Browse files Browse the repository at this point in the history
…in the right file
  • Loading branch information
tlhmerry0098 committed Dec 23, 2024
1 parent cd29e4a commit b01d84d
Show file tree
Hide file tree
Showing 6 changed files with 88 additions and 66 deletions.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ libcnb-test = "=0.26.0"
regex = "1"
strip-ansi-escapes = "0.2"
tempfile = "3"
buildpacks-deb-packages = { path = "." }

[lints.rust]
unreachable_pub = "warn"
Expand Down
25 changes: 25 additions & 0 deletions src/debian/multiarch_name.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
use std::fmt::{Display, Formatter};

use crate::debian::ArchitectureName;
use std::str::FromStr;
// use std::fmt::{Display, Formatter};

#[derive(Debug, PartialEq, Clone)]
#[allow(non_camel_case_types)]
Expand Down Expand Up @@ -28,9 +30,32 @@ impl Display for MultiarchName {
}
}

impl FromStr for MultiarchName {
type Err = ();

fn from_str(s: &str) -> Result<Self, Self::Err> {
match s {
"x86_64-linux-gnu" => Ok(MultiarchName::X86_64_LINUX_GNU),
"aarch64-linux-gnu" => Ok(MultiarchName::AARCH_64_LINUX_GNU),
_ => Err(()),
}
}
}

#[cfg(test)]
mod tests {
use super::*;
use std::str::FromStr;

#[test]
fn test_multiarch_name_from_str() {
// Test valid strings
assert_eq!(MultiarchName::from_str("x86_64-linux-gnu").unwrap(), MultiarchName::X86_64_LINUX_GNU);
assert_eq!(MultiarchName::from_str("aarch64-linux-gnu").unwrap(), MultiarchName::AARCH_64_LINUX_GNU);

// Test invalid string
assert!(MultiarchName::from_str("invalid-arch").is_err());
}

#[test]
fn converting_architecture_name_to_multiarch_name() {
Expand Down
24 changes: 23 additions & 1 deletion src/install_packages.rs
Original file line number Diff line number Diff line change
Expand Up @@ -315,7 +315,7 @@ async fn extract(download_path: PathBuf, output_dir: PathBuf) -> BuildpackResult
}

// Modified function to include setting GIT_EXEC_PATH
pub(crate) fn configure_layer_environment(install_path: &Path, multiarch_name: &MultiarchName) -> LayerEnv {
fn configure_layer_environment(install_path: &Path, multiarch_name: &MultiarchName) -> LayerEnv {
let mut layer_env = LayerEnv::new();

let bin_paths = [
Expand Down Expand Up @@ -612,3 +612,25 @@ mod test {
.unwrap_or_default()
}
}

#[cfg(test)]
mod unit_tests {
use std::path::PathBuf;
use libcnb::layer_env::Scope;
use crate::install_packages::configure_layer_environment;
use crate::debian::MultiarchName;
use std::str::FromStr;

#[test]
fn test_configure_layer_environment_sets_git_exec_path() {
let install_path = PathBuf::from("/mock/install/path");
let multiarch_name = MultiarchName::from_str("x86_64-linux-gnu").unwrap();
let layer_env = configure_layer_environment(&install_path, &multiarch_name);

assert_eq!(
layer_env.apply_to_empty(Scope::All).get("GIT_EXEC_PATH").map(|s| s.to_string_lossy().into_owned()),
// layer_env.apply_to_empty(Scope::All).get("GIT_EXEC_PATH"),
Some("/mock/install/path/usr/lib/git-core".to_string())
);
}
}
2 changes: 1 addition & 1 deletion src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ mod create_package_index;
mod debian;
mod determine_packages_to_install;
mod errors;
pub mod install_packages;
mod install_packages;
mod pgp;

buildpack_main!(DebianPackagesBuildpack);
Expand Down
101 changes: 37 additions & 64 deletions tests/integration_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -621,73 +621,46 @@ fn update_project_toml(app_dir: &Path, update_fn: impl FnOnce(&mut DocumentMut))
std::fs::write(&project_toml, doc.to_string()).unwrap();
}

#[cfg(test)]
mod unit_tests {
use std::path::PathBuf;
use libcnb::layer_env::Scope;
use buildpacks_deb_packages::install_packages::configure_layer_environment;
use buildpacks_deb_packages::debian::MultiarchName;

#[test]
fn test_configure_layer_environment_sets_git_exec_path() {
let install_path = PathBuf::from("/mock/install/path");
let multiarch_name = MultiarchName::from("x86_64-linux-gnu");
let layer_env = configure_layer_environment(&install_path, &multiarch_name);

assert_eq!(
layer_env.apply_to_empty(Scope::All).get("GIT_EXEC_PATH"),
Some("/mock/install/path/usr/lib/git-core".into())
);
}

#[test]
fn test_get_integration_test_builder() {
// Set environment variable
std::env::set_var("INTEGRATION_TEST_CNB_BUILDER", "heroku/builder:24");
assert_eq!(get_integration_test_builder(), "heroku/builder:24");

// Unset environment variable
std::env::remove_var("INTEGRATION_TEST_CNB_BUILDER");
assert_eq!(get_integration_test_builder(), DEFAULT_BUILDER);
}

#[test]
fn test_get_integration_test_arch() {
// Set environment variable
std::env::set_var("INTEGRATION_TEST_CNB_ARCH", "arm64");
assert_eq!(get_integration_test_arch(), "arm64");

// Unset environment variable
std::env::remove_var("INTEGRATION_TEST_CNB_ARCH");
assert_eq!(get_integration_test_arch(), DEFAULT_ARCH);
}
#[test]
fn test_get_integration_test_builder() {
// Set environment variable
std::env::set_var("INTEGRATION_TEST_CNB_BUILDER", "heroku/builder:24");
assert_eq!(get_integration_test_builder(), "heroku/builder:24");

// Unset environment variable
std::env::remove_var("INTEGRATION_TEST_CNB_BUILDER");
assert_eq!(get_integration_test_builder(), DEFAULT_BUILDER);
}

#[test]
fn test_panic_unsupported_test_configuration() {
// This test should panic
let result = std::panic::catch_unwind(|| {
panic_unsupported_test_configuration();
});
assert!(result.is_err());
}
#[test]
fn test_get_integration_test_arch() {
// Set environment variable
std::env::set_var("INTEGRATION_TEST_CNB_ARCH", "arm64");
assert_eq!(get_integration_test_arch(), "arm64");

// Unset environment variable
std::env::remove_var("INTEGRATION_TEST_CNB_ARCH");
assert_eq!(get_integration_test_arch(), DEFAULT_ARCH);
}

// #[test]
// fn test_requested_package_config() {
// let config = requested_package_config("ffmpeg", true);
// assert_eq!(config.get("name").unwrap(), "ffmpeg");
// assert_eq!(config.get("skip_dependencies").unwrap(), "true");
// }
#[test]
fn test_panic_unsupported_test_configuration() {
// This test should panic
let result = std::panic::catch_unwind(|| {
panic_unsupported_test_configuration();
});
assert!(result.is_err());
}

#[test]
fn test_set_install_config() {
let temp_dir = tempfile::tempdir().unwrap();
let app_dir = temp_dir.path();
std::fs::write(app_dir.join("project.toml"), "[com.heroku.buildpacks.deb-packages]").unwrap();
#[test]
fn test_set_install_config() {
let temp_dir = tempfile::tempdir().unwrap();
let app_dir = temp_dir.path();
std::fs::write(app_dir.join("project.toml"), "[com.heroku.buildpacks.deb-packages]").unwrap();

set_install_config(app_dir, [requested_package_config("ffmpeg", true)]);
set_install_config(app_dir, [requested_package_config("ffmpeg", true)]);

let contents = std::fs::read_to_string(app_dir.join("project.toml")).unwrap();
assert!(contents.contains("ffmpeg"));
assert!(contents.contains("skip_dependencies = true"));
}
let contents = std::fs::read_to_string(app_dir.join("project.toml")).unwrap();
assert!(contents.contains("ffmpeg"));
assert!(contents.contains("skip_dependencies = true"));
}

0 comments on commit b01d84d

Please sign in to comment.