80a7e2644c
...and cleanup, making how we handle version numbers more rational (specifically, not passing in a versioned name to rustc with the -o flag), and removing unused code.
233 lines
7.7 KiB
Rust
233 lines
7.7 KiB
Rust
// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
// rustpkg unit tests
|
|
|
|
use context::Ctx;
|
|
use core::hashmap::HashMap;
|
|
use core::path::Path;
|
|
use std::tempfile::mkdtemp;
|
|
use util::{PkgId, default_version};
|
|
use path_util::{target_executable_in_workspace, target_library_in_workspace,
|
|
target_test_in_workspace, target_bench_in_workspace,
|
|
make_dir_rwx, u_rwx, RemotePath, LocalPath, normalize,
|
|
built_bench_in_workspace, built_test_in_workspace};
|
|
|
|
fn fake_ctxt(sysroot_opt: Option<@Path>) -> Ctx {
|
|
Ctx {
|
|
sysroot_opt: sysroot_opt,
|
|
json: false,
|
|
dep_cache: @mut HashMap::new()
|
|
}
|
|
}
|
|
|
|
fn fake_pkg() -> PkgId {
|
|
let sn = ~"bogus";
|
|
let remote = RemotePath(Path(sn));
|
|
PkgId {
|
|
local_path: normalize(copy remote),
|
|
remote_path: remote,
|
|
short_name: sn,
|
|
version: default_version()
|
|
}
|
|
}
|
|
|
|
fn remote_pkg() -> PkgId {
|
|
let remote = RemotePath(Path(~"github.com/catamorphism/test-pkg"));
|
|
PkgId {
|
|
local_path: normalize(copy remote),
|
|
remote_path: remote,
|
|
short_name: ~"test_pkg",
|
|
version: default_version()
|
|
}
|
|
}
|
|
|
|
fn writeFile(file_path: &Path, contents: ~str) {
|
|
let out: @io::Writer =
|
|
result::get(&io::file_writer(file_path,
|
|
~[io::Create, io::Truncate]));
|
|
out.write_line(contents);
|
|
}
|
|
|
|
fn mk_temp_workspace(short_name: &LocalPath) -> Path {
|
|
let workspace = mkdtemp(&os::tmpdir(), "test").expect("couldn't create temp dir");
|
|
// include version number in directory name
|
|
let package_dir = workspace.push(~"src").push(fmt!("%s-0.1", short_name.to_str()));
|
|
assert!(os::mkdir_recursive(&package_dir, u_rwx));
|
|
// Create main, lib, test, and bench files
|
|
writeFile(&package_dir.push(~"main.rs"),
|
|
~"fn main() { let _x = (); }");
|
|
writeFile(&package_dir.push(~"lib.rs"),
|
|
~"pub fn f() { let _x = (); }");
|
|
writeFile(&package_dir.push(~"test.rs"),
|
|
~"#[test] pub fn f() { (); }");
|
|
writeFile(&package_dir.push(~"bench.rs"),
|
|
~"#[bench] pub fn f() { (); }");
|
|
workspace
|
|
}
|
|
|
|
fn is_rwx(p: &Path) -> bool {
|
|
use core::libc::consts::os::posix88::{S_IRUSR, S_IWUSR, S_IXUSR};
|
|
|
|
match p.get_mode() {
|
|
None => return false,
|
|
Some(m) =>
|
|
((m & S_IRUSR as uint) == S_IRUSR as uint
|
|
&& (m & S_IWUSR as uint) == S_IWUSR as uint
|
|
&& (m & S_IXUSR as uint) == S_IXUSR as uint)
|
|
}
|
|
}
|
|
|
|
fn test_sysroot() -> Path {
|
|
// Totally gross hack but it's just for test cases.
|
|
// Infer the sysroot from the exe name and pray that it's right.
|
|
// (Did I mention it was a gross hack?)
|
|
let self_path = os::self_exe_path().expect("Couldn't get self_exe path");
|
|
self_path.pop()
|
|
}
|
|
|
|
#[test]
|
|
fn test_make_dir_rwx() {
|
|
let temp = &os::tmpdir();
|
|
let dir = temp.push(~"quux");
|
|
assert!(!os::path_exists(&dir) ||
|
|
os::remove_dir_recursive(&dir));
|
|
debug!("Trying to make %s", dir.to_str());
|
|
assert!(make_dir_rwx(&dir));
|
|
assert!(os::path_is_dir(&dir));
|
|
assert!(is_rwx(&dir));
|
|
assert!(os::remove_dir_recursive(&dir));
|
|
}
|
|
|
|
#[test]
|
|
fn test_install_valid() {
|
|
let sysroot = test_sysroot();
|
|
debug!("sysroot = %s", sysroot.to_str());
|
|
let ctxt = fake_ctxt(Some(@sysroot));
|
|
let temp_pkg_id = fake_pkg();
|
|
let temp_workspace = mk_temp_workspace(&temp_pkg_id.local_path);
|
|
// should have test, bench, lib, and main
|
|
ctxt.install(&temp_workspace, &temp_pkg_id);
|
|
// Check that all files exist
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, &temp_workspace);
|
|
debug!("exec = %s", exec.to_str());
|
|
assert!(os::path_exists(&exec));
|
|
assert!(is_rwx(&exec));
|
|
let lib = target_library_in_workspace(&temp_pkg_id, &temp_workspace);
|
|
debug!("lib = %s", lib.to_str());
|
|
assert!(os::path_exists(&lib));
|
|
assert!(is_rwx(&lib));
|
|
// And that the test and bench executables aren't installed
|
|
assert!(!os::path_exists(&target_test_in_workspace(&temp_pkg_id, &temp_workspace)));
|
|
let bench = target_bench_in_workspace(&temp_pkg_id, &temp_workspace);
|
|
debug!("bench = %s", bench.to_str());
|
|
assert!(!os::path_exists(&bench));
|
|
}
|
|
|
|
#[test]
|
|
fn test_install_invalid() {
|
|
use conditions::nonexistent_package::cond;
|
|
use cond1 = conditions::missing_pkg_files::cond;
|
|
|
|
let ctxt = fake_ctxt(None);
|
|
let pkgid = fake_pkg();
|
|
let temp_workspace = mkdtemp(&os::tmpdir(), "test").expect("couldn't create temp dir");
|
|
let mut error_occurred = false;
|
|
let mut error1_occurred = false;
|
|
do cond1.trap(|_| {
|
|
error1_occurred = true;
|
|
}).in {
|
|
do cond.trap(|_| {
|
|
error_occurred = true;
|
|
}).in {
|
|
ctxt.install(&temp_workspace, &pkgid);
|
|
}
|
|
}
|
|
assert!(error_occurred && error1_occurred);
|
|
}
|
|
|
|
#[test]
|
|
fn test_install_url() {
|
|
let workspace = mkdtemp(&os::tmpdir(), "test").expect("couldn't create temp dir");
|
|
let sysroot = test_sysroot();
|
|
debug!("sysroot = %s", sysroot.to_str());
|
|
let ctxt = fake_ctxt(Some(@sysroot));
|
|
let temp_pkg_id = remote_pkg();
|
|
// should have test, bench, lib, and main
|
|
ctxt.install(&workspace, &temp_pkg_id);
|
|
// Check that all files exist
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, &workspace);
|
|
debug!("exec = %s", exec.to_str());
|
|
assert!(os::path_exists(&exec));
|
|
assert!(is_rwx(&exec));
|
|
let lib = target_library_in_workspace(&temp_pkg_id, &workspace);
|
|
debug!("lib = %s", lib.to_str());
|
|
assert!(os::path_exists(&lib));
|
|
assert!(is_rwx(&lib));
|
|
let built_test = built_test_in_workspace(&temp_pkg_id, &workspace).expect(~"test_install_url");
|
|
assert!(os::path_exists(&built_test));
|
|
let built_bench = built_bench_in_workspace(&temp_pkg_id,
|
|
&workspace).expect(~"test_install_url");
|
|
assert!(os::path_exists(&built_bench));
|
|
// And that the test and bench executables aren't installed
|
|
let test = target_test_in_workspace(&temp_pkg_id, &workspace);
|
|
assert!(!os::path_exists(&test));
|
|
debug!("test = %s", test.to_str());
|
|
let bench = target_bench_in_workspace(&temp_pkg_id, &workspace);
|
|
debug!("bench = %s", bench.to_str());
|
|
assert!(!os::path_exists(&bench));
|
|
}
|
|
|
|
#[test]
|
|
fn test_package_ids_must_be_relative_path_like() {
|
|
use conditions::bad_pkg_id::cond;
|
|
|
|
/*
|
|
Okay:
|
|
- One identifier, with no slashes
|
|
- Several slash-delimited things, with no / at the root
|
|
|
|
Not okay:
|
|
- Empty string
|
|
- Absolute path (as per os::is_absolute)
|
|
|
|
*/
|
|
|
|
let default_version_str = "0.1";
|
|
let addversion = |s| {
|
|
fmt!("%s-%s", s, default_version_str)
|
|
};
|
|
|
|
let whatever = PkgId::new("foo");
|
|
|
|
assert!(addversion("foo") == whatever.to_str());
|
|
assert!(addversion("github.com/mozilla/rust") ==
|
|
PkgId::new("github.com/mozilla/rust").to_str());
|
|
|
|
do cond.trap(|(p, e)| {
|
|
assert!("" == p.to_str());
|
|
assert!("0-length pkgid" == e);
|
|
copy whatever
|
|
}).in {
|
|
let x = PkgId::new("");
|
|
assert!(addversion("foo") == x.to_str());
|
|
}
|
|
|
|
do cond.trap(|(p, e)| {
|
|
assert!(p.to_str() == os::make_absolute(&Path("foo/bar/quux")).to_str());
|
|
assert!("absolute pkgid" == e);
|
|
copy whatever
|
|
}).in {
|
|
let z = PkgId::new(os::make_absolute(&Path("foo/bar/quux")).to_str());
|
|
assert!(addversion("foo") == z.to_str());
|
|
}
|
|
|
|
}
|