2013-04-12 16:15:40 -07:00
|
|
|
// 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
|
2013-04-24 17:37:59 -07:00
|
|
|
|
|
|
|
use context::Ctx;
|
2013-06-28 18:32:26 -04:00
|
|
|
use std::hashmap::HashMap;
|
2013-07-11 18:20:31 -07:00
|
|
|
use std::{io, libc, os, result, run, str};
|
2013-05-24 19:35:29 -07:00
|
|
|
use extra::tempfile::mkdtemp;
|
2013-06-28 18:32:26 -04:00
|
|
|
use std::run::ProcessOutput;
|
2013-07-11 18:20:31 -07:00
|
|
|
use installed_packages::list_installed_packages;
|
2013-05-27 17:45:16 -07:00
|
|
|
use package_path::*;
|
2013-06-14 18:16:24 -07:00
|
|
|
use package_id::{PkgId};
|
2013-07-24 18:42:14 -07:00
|
|
|
use version::{ExactRevision, NoVersion, Version, Tagged};
|
2013-04-24 17:37:59 -07:00
|
|
|
use path_util::{target_executable_in_workspace, target_library_in_workspace,
|
|
|
|
target_test_in_workspace, target_bench_in_workspace,
|
2013-07-01 13:51:13 +10:00
|
|
|
make_dir_rwx, U_RWX, library_in_workspace,
|
2013-06-01 15:59:12 -07:00
|
|
|
built_bench_in_workspace, built_test_in_workspace,
|
|
|
|
built_library_in_workspace, built_executable_in_workspace,
|
2013-06-25 19:49:01 -07:00
|
|
|
installed_library_in_workspace, rust_path};
|
2013-06-14 18:16:24 -07:00
|
|
|
use target::*;
|
|
|
|
|
|
|
|
/// Returns the last-modified date as an Option
|
|
|
|
fn datestamp(p: &Path) -> Option<libc::time_t> {
|
|
|
|
p.stat().map(|stat| stat.st_mtime)
|
|
|
|
}
|
2013-04-24 17:37:59 -07:00
|
|
|
|
2013-05-03 16:47:53 -07:00
|
|
|
fn fake_ctxt(sysroot_opt: Option<@Path>) -> Ctx {
|
2013-04-24 17:37:59 -07:00
|
|
|
Ctx {
|
2013-05-03 16:47:53 -07:00
|
|
|
sysroot_opt: sysroot_opt,
|
2013-04-24 17:37:59 -07:00
|
|
|
json: false,
|
|
|
|
dep_cache: @mut HashMap::new()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fake_pkg() -> PkgId {
|
2013-05-10 19:00:51 -07:00
|
|
|
let sn = ~"bogus";
|
|
|
|
let remote = RemotePath(Path(sn));
|
2013-04-24 17:37:59 -07:00
|
|
|
PkgId {
|
2013-07-02 12:47:32 -07:00
|
|
|
local_path: normalize(remote.clone()),
|
2013-05-10 19:00:51 -07:00
|
|
|
remote_path: remote,
|
|
|
|
short_name: sn,
|
2013-06-01 15:59:12 -07:00
|
|
|
version: NoVersion
|
2013-04-24 17:37:59 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-09 18:28:00 -07:00
|
|
|
fn git_repo_pkg() -> PkgId {
|
|
|
|
let remote = RemotePath(Path("mockgithub.com/catamorphism/test-pkg"));
|
2013-05-03 16:47:53 -07:00
|
|
|
PkgId {
|
2013-07-02 12:47:32 -07:00
|
|
|
local_path: normalize(remote.clone()),
|
2013-05-10 19:00:51 -07:00
|
|
|
remote_path: remote,
|
|
|
|
short_name: ~"test_pkg",
|
2013-06-01 15:59:12 -07:00
|
|
|
version: NoVersion
|
2013-05-30 12:03:21 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-24 18:42:14 -07:00
|
|
|
fn git_repo_pkg_with_tag(a_tag: ~str) -> PkgId {
|
|
|
|
let remote = RemotePath(Path("mockgithub.com/catamorphism/test-pkg"));
|
|
|
|
PkgId {
|
|
|
|
local_path: normalize(remote.clone()),
|
|
|
|
remote_path: remote,
|
|
|
|
short_name: ~"test_pkg",
|
|
|
|
version: Tagged(a_tag)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-27 17:45:16 -07:00
|
|
|
fn writeFile(file_path: &Path, contents: &str) {
|
2013-05-02 13:09:28 -07:00
|
|
|
let out: @io::Writer =
|
2013-07-11 12:05:17 -07:00
|
|
|
result::unwrap(io::file_writer(file_path,
|
|
|
|
[io::Create, io::Truncate]));
|
2013-05-02 13:09:28 -07:00
|
|
|
out.write_line(contents);
|
|
|
|
}
|
|
|
|
|
2013-06-01 15:59:12 -07:00
|
|
|
fn mk_empty_workspace(short_name: &LocalPath, version: &Version) -> Path {
|
2013-06-14 18:16:24 -07:00
|
|
|
let workspace_dir = mkdtemp(&os::tmpdir(), "test").expect("couldn't create temp dir");
|
|
|
|
mk_workspace(&workspace_dir, short_name, version);
|
|
|
|
workspace_dir
|
|
|
|
}
|
|
|
|
|
|
|
|
fn mk_workspace(workspace: &Path, short_name: &LocalPath, version: &Version) -> Path {
|
2013-05-14 17:46:52 -07:00
|
|
|
// include version number in directory name
|
2013-06-14 18:16:24 -07:00
|
|
|
let package_dir = workspace.push("src").push(fmt!("%s-%s",
|
2013-06-01 15:59:12 -07:00
|
|
|
short_name.to_str(), version.to_str()));
|
2013-07-01 13:51:13 +10:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
2013-06-14 18:16:24 -07:00
|
|
|
package_dir
|
2013-06-01 15:59:12 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
fn mk_temp_workspace(short_name: &LocalPath, version: &Version) -> Path {
|
|
|
|
let package_dir = mk_empty_workspace(short_name,
|
2013-06-14 18:16:24 -07:00
|
|
|
version).push("src").push(fmt!("%s-%s",
|
2013-06-01 15:59:12 -07:00
|
|
|
short_name.to_str(),
|
|
|
|
version.to_str()));
|
|
|
|
|
2013-05-27 17:45:16 -07:00
|
|
|
debug!("Created %s and does it exist? %?", package_dir.to_str(),
|
|
|
|
os::path_is_dir(&package_dir));
|
2013-05-02 13:09:28 -07:00
|
|
|
// Create main, lib, test, and bench files
|
2013-06-14 18:16:24 -07:00
|
|
|
debug!("mk_workspace: creating %s", package_dir.to_str());
|
2013-07-01 13:51:13 +10:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
2013-06-14 18:16:24 -07:00
|
|
|
debug!("Created %s and does it exist? %?", package_dir.to_str(),
|
|
|
|
os::path_is_dir(&package_dir));
|
|
|
|
// Create main, lib, test, and bench files
|
|
|
|
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("main.rs"),
|
2013-05-27 17:45:16 -07:00
|
|
|
"fn main() { let _x = (); }");
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("lib.rs"),
|
2013-05-27 17:45:16 -07:00
|
|
|
"pub fn f() { let _x = (); }");
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("test.rs"),
|
2013-05-27 17:45:16 -07:00
|
|
|
"#[test] pub fn f() { (); }");
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("bench.rs"),
|
2013-05-27 17:45:16 -07:00
|
|
|
"#[bench] pub fn f() { (); }");
|
2013-06-14 18:16:24 -07:00
|
|
|
package_dir
|
2013-04-24 17:37:59 -07:00
|
|
|
}
|
|
|
|
|
2013-07-09 18:28:00 -07:00
|
|
|
/// Should create an empty git repo in p, relative to the tmp dir, and return the new
|
|
|
|
/// absolute path
|
|
|
|
fn init_git_repo(p: &Path) -> Path {
|
|
|
|
assert!(!p.is_absolute());
|
|
|
|
let tmp = mkdtemp(&os::tmpdir(), "git_local").expect("couldn't create temp dir");
|
|
|
|
let work_dir = tmp.push_rel(p);
|
|
|
|
let work_dir_for_opts = work_dir.clone();
|
|
|
|
assert!(os::mkdir_recursive(&work_dir, U_RWX));
|
|
|
|
debug!("Running: git init in %s", work_dir.to_str());
|
|
|
|
let opts = run::ProcessOptions {
|
|
|
|
env: None,
|
|
|
|
dir: Some(&work_dir_for_opts),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
};
|
|
|
|
let mut prog = run::Process::new("git", [~"init"], opts);
|
|
|
|
let mut output = prog.finish_with_output();
|
|
|
|
if output.status == 0 {
|
|
|
|
// Add stuff to the dir so that git tag succeeds
|
|
|
|
writeFile(&work_dir.push("README"), "");
|
|
|
|
prog = run::Process::new("git", [~"add", ~"README"], opts);
|
|
|
|
output = prog.finish_with_output();
|
|
|
|
if output.status == 0 {
|
|
|
|
prog = run::Process::new("git", [~"commit", ~"-m", ~"whatever"], opts);
|
|
|
|
output = prog.finish_with_output();
|
|
|
|
if output.status == 0 {
|
|
|
|
tmp
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fail!("Couldn't commit in %s", work_dir.to_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fail!("Couldn't add in %s", work_dir.to_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
fail!("Couldn't initialize git repository in %s", work_dir.to_str())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-24 18:42:14 -07:00
|
|
|
fn add_all_and_commit(repo: &Path) {
|
|
|
|
git_add_all(repo);
|
|
|
|
git_commit(repo, ~"floop");
|
|
|
|
}
|
|
|
|
|
|
|
|
fn git_commit(repo: &Path, msg: ~str) {
|
|
|
|
let mut prog = run::Process::new("git", [~"commit", ~"-m", msg],
|
2013-07-09 18:28:00 -07:00
|
|
|
run::ProcessOptions { env: None,
|
|
|
|
dir: Some(repo),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
let output = prog.finish_with_output();
|
|
|
|
if output.status != 0 {
|
2013-07-24 18:42:14 -07:00
|
|
|
fail!("Couldn't commit in %s: output was %s", repo.to_str(),
|
|
|
|
str::from_bytes(output.output + output.error))
|
2013-07-09 18:28:00 -07:00
|
|
|
}
|
2013-07-24 18:42:14 -07:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
fn git_add_all(repo: &Path) {
|
|
|
|
let mut prog = run::Process::new("git", [~"add", ~"-A"],
|
2013-07-09 18:28:00 -07:00
|
|
|
run::ProcessOptions { env: None,
|
|
|
|
dir: Some(repo),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
let output = prog.finish_with_output();
|
|
|
|
if output.status != 0 {
|
2013-07-24 18:42:14 -07:00
|
|
|
fail!("Couldn't add all files in %s: output was %s",
|
|
|
|
repo.to_str(), str::from_bytes(output.output + output.error))
|
2013-07-09 18:28:00 -07:00
|
|
|
}
|
2013-07-24 18:42:14 -07:00
|
|
|
}
|
2013-07-09 18:28:00 -07:00
|
|
|
|
2013-07-24 18:42:14 -07:00
|
|
|
fn add_git_tag(repo: &Path, tag: ~str) {
|
|
|
|
assert!(repo.is_absolute());
|
|
|
|
git_add_all(repo);
|
|
|
|
git_commit(repo, ~"whatever");
|
|
|
|
let mut prog = run::Process::new("git", [~"tag", tag.clone()],
|
2013-07-09 18:28:00 -07:00
|
|
|
run::ProcessOptions { env: None,
|
|
|
|
dir: Some(repo),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
let output = prog.finish_with_output();
|
|
|
|
if output.status != 0 {
|
|
|
|
fail!("Couldn't add git tag %s in %s", tag, repo.to_str())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-24 17:37:59 -07:00
|
|
|
fn is_rwx(p: &Path) -> bool {
|
2013-06-28 18:32:26 -04:00
|
|
|
use std::libc::consts::os::posix88::{S_IRUSR, S_IWUSR, S_IXUSR};
|
2013-04-24 17:37:59 -07:00
|
|
|
|
|
|
|
match p.get_mode() {
|
|
|
|
None => return false,
|
2013-05-02 13:09:28 -07:00
|
|
|
Some(m) =>
|
2013-04-24 17:37:59 -07:00
|
|
|
((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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-03 16:47:53 -07:00
|
|
|
fn test_sysroot() -> Path {
|
|
|
|
// Totally gross hack but it's just for test cases.
|
2013-05-14 10:25:13 -04:00
|
|
|
// Infer the sysroot from the exe name and pray that it's right.
|
|
|
|
// (Did I mention it was a gross hack?)
|
2013-05-03 16:47:53 -07:00
|
|
|
let self_path = os::self_exe_path().expect("Couldn't get self_exe path");
|
2013-05-14 10:25:13 -04:00
|
|
|
self_path.pop()
|
2013-05-03 16:47:53 -07:00
|
|
|
}
|
|
|
|
|
2013-07-11 18:20:31 -07:00
|
|
|
fn command_line_test(args: &[~str], cwd: &Path) -> ProcessOutput {
|
|
|
|
command_line_test_with_env(args, cwd, None)
|
|
|
|
}
|
|
|
|
|
2013-06-14 18:16:24 -07:00
|
|
|
/// Runs `rustpkg` (based on the directory that this executable was
|
|
|
|
/// invoked from) with the given arguments, in the given working directory.
|
|
|
|
/// Returns the process's output.
|
2013-07-11 18:20:31 -07:00
|
|
|
fn command_line_test_with_env(args: &[~str], cwd: &Path, env: Option<~[(~str, ~str)]>)
|
|
|
|
-> ProcessOutput {
|
2013-06-14 18:16:24 -07:00
|
|
|
let cmd = test_sysroot().push("bin").push("rustpkg").to_str();
|
|
|
|
debug!("About to run command: %? %? in %s", cmd, args, cwd.to_str());
|
|
|
|
assert!(os::path_is_dir(&*cwd));
|
2013-07-16 23:49:42 -07:00
|
|
|
let cwd = (*cwd).clone();
|
2013-07-11 18:20:31 -07:00
|
|
|
let mut prog = run::Process::new(cmd, args, run::ProcessOptions {
|
|
|
|
env: env.map(|v| v.slice(0, v.len())),
|
|
|
|
dir: Some(&cwd),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
2013-06-14 18:16:24 -07:00
|
|
|
let output = prog.finish_with_output();
|
2013-06-27 16:27:13 -07:00
|
|
|
debug!("Output from command %s with args %? was %s {%s}[%?]",
|
2013-06-14 18:16:24 -07:00
|
|
|
cmd, args, str::from_bytes(output.output),
|
|
|
|
str::from_bytes(output.error),
|
2013-06-27 16:27:13 -07:00
|
|
|
output.status);
|
2013-06-14 18:16:24 -07:00
|
|
|
/*
|
|
|
|
By the way, rustpkg *won't* return a nonzero exit code if it fails --
|
|
|
|
see #4547
|
|
|
|
So tests that use this need to check the existence of a file
|
|
|
|
to make sure the command succeeded
|
|
|
|
*/
|
|
|
|
if output.status != 0 {
|
|
|
|
fail!("Command %s %? failed with exit code %?",
|
|
|
|
cmd, args, output.status);
|
|
|
|
}
|
|
|
|
output
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package(pkgid: &PkgId) -> Path {
|
|
|
|
let parent_dir = mk_temp_workspace(&pkgid.local_path, &pkgid.version);
|
|
|
|
debug!("Created empty package dir for %s, returning %s", pkgid.to_str(), parent_dir.to_str());
|
|
|
|
parent_dir.pop().pop()
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package_in(pkgid: &PkgId, pkgdir: &Path) -> Path {
|
|
|
|
|
|
|
|
let package_dir = pkgdir.push("src").push(pkgid.to_str());
|
|
|
|
|
|
|
|
// Create main, lib, test, and bench files
|
2013-07-01 13:51:13 +10:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
2013-06-14 18:16:24 -07:00
|
|
|
debug!("Created %s and does it exist? %?", package_dir.to_str(),
|
|
|
|
os::path_is_dir(&package_dir));
|
|
|
|
// 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() { (); }");
|
|
|
|
package_dir
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package_with_test(pkgid: &PkgId) -> Path {
|
|
|
|
debug!("Dry run -- would create package %s with test");
|
|
|
|
create_local_package(pkgid) // Already has tests???
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package_with_dep(pkgid: &PkgId, subord_pkgid: &PkgId) -> Path {
|
|
|
|
let package_dir = create_local_package(pkgid);
|
|
|
|
create_local_package_in(subord_pkgid, &package_dir);
|
|
|
|
// Write a main.rs file into pkgid that references subord_pkgid
|
|
|
|
writeFile(&package_dir.push("src").push(pkgid.to_str()).push("main.rs"),
|
|
|
|
fmt!("extern mod %s;\nfn main() {}",
|
|
|
|
subord_pkgid.short_name));
|
|
|
|
// Write a lib.rs file into subord_pkgid that has something in it
|
|
|
|
writeFile(&package_dir.push("src").push(subord_pkgid.to_str()).push("lib.rs"),
|
|
|
|
"pub fn f() {}");
|
|
|
|
debug!("Dry run -- would create packages %s and %s in %s",
|
|
|
|
pkgid.to_str(),
|
|
|
|
subord_pkgid.to_str(),
|
|
|
|
package_dir.to_str());
|
|
|
|
package_dir
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package_with_custom_build_hook(pkgid: &PkgId,
|
|
|
|
custom_build_hook: &str) -> Path {
|
|
|
|
debug!("Dry run -- would create package %s with custom build hook %s",
|
|
|
|
pkgid.to_str(), custom_build_hook);
|
|
|
|
create_local_package(pkgid)
|
|
|
|
// actually write the pkg.rs with the custom build hook
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-07-09 18:28:00 -07:00
|
|
|
fn assert_lib_exists(repo: &Path, short_name: &str, v: Version) {
|
2013-06-14 18:16:24 -07:00
|
|
|
debug!("assert_lib_exists: repo = %s, short_name = %s", repo.to_str(), short_name);
|
2013-07-09 18:28:00 -07:00
|
|
|
let lib = target_library_in_workspace(&(PkgId {
|
|
|
|
version: v, ..PkgId::new(short_name, repo)}
|
|
|
|
), repo);
|
|
|
|
debug!("assert_lib_exists: checking whether %s exists", lib.to_str());
|
2013-06-14 18:16:24 -07:00
|
|
|
assert!(os::path_exists(&lib));
|
|
|
|
assert!(is_rwx(&lib));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn assert_executable_exists(repo: &Path, short_name: &str) {
|
|
|
|
debug!("assert_executable_exists: repo = %s, short_name = %s", repo.to_str(), short_name);
|
2013-07-09 18:28:00 -07:00
|
|
|
let exec = target_executable_in_workspace(&PkgId::new(short_name, repo), repo);
|
2013-06-14 18:16:24 -07:00
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
|
|
|
}
|
|
|
|
|
2013-06-26 17:42:24 -07:00
|
|
|
fn assert_built_executable_exists(repo: &Path, short_name: &str) {
|
|
|
|
debug!("assert_built_executable_exists: repo = %s, short_name = %s", repo.to_str(), short_name);
|
|
|
|
let exec = built_executable_in_workspace(&PkgId::new(short_name, repo),
|
|
|
|
repo).expect("assert_built_executable_exists failed");
|
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
|
|
|
}
|
|
|
|
|
2013-06-14 18:16:24 -07:00
|
|
|
fn command_line_test_output(args: &[~str]) -> ~[~str] {
|
|
|
|
let mut result = ~[];
|
|
|
|
let p_output = command_line_test(args, &os::getcwd());
|
|
|
|
let test_output = str::from_bytes(p_output.output);
|
|
|
|
for test_output.split_iter('\n').advance |s| {
|
2013-06-25 18:25:27 -07:00
|
|
|
result.push(s.to_owned());
|
2013-06-14 18:16:24 -07:00
|
|
|
}
|
|
|
|
result
|
|
|
|
}
|
|
|
|
|
2013-07-11 18:20:31 -07:00
|
|
|
fn command_line_test_output_with_env(args: &[~str], env: ~[(~str, ~str)]) -> ~[~str] {
|
|
|
|
let mut result = ~[];
|
|
|
|
let p_output = command_line_test_with_env(args, &os::getcwd(), Some(env));
|
|
|
|
let test_output = str::from_bytes(p_output.output);
|
|
|
|
for test_output.split_iter('\n').advance |s| {
|
|
|
|
result.push(s.to_owned());
|
|
|
|
}
|
|
|
|
result
|
|
|
|
}
|
|
|
|
|
2013-06-14 18:16:24 -07:00
|
|
|
// assumes short_name and local_path are one and the same -- I should fix
|
|
|
|
fn lib_output_file_name(workspace: &Path, parent: &str, short_name: &str) -> Path {
|
|
|
|
debug!("lib_output_file_name: given %s and parent %s and short name %s",
|
|
|
|
workspace.to_str(), parent, short_name);
|
|
|
|
library_in_workspace(&normalize(RemotePath(Path(short_name))),
|
|
|
|
short_name,
|
|
|
|
Build,
|
|
|
|
workspace,
|
|
|
|
"build").expect("lib_output_file_name")
|
|
|
|
}
|
|
|
|
|
|
|
|
fn output_file_name(workspace: &Path, short_name: &str) -> Path {
|
|
|
|
workspace.push(fmt!("%s%s", short_name, os::EXE_SUFFIX))
|
|
|
|
}
|
|
|
|
|
2013-06-21 12:38:10 -07:00
|
|
|
fn touch_source_file(workspace: &Path, pkgid: &PkgId) {
|
2013-06-14 18:16:24 -07:00
|
|
|
use conditions::bad_path::cond;
|
2013-06-21 12:38:10 -07:00
|
|
|
let pkg_src_dir = workspace.push("src").push(pkgid.to_str());
|
|
|
|
let contents = os::list_dir_path(&pkg_src_dir);
|
2013-06-21 08:29:53 -04:00
|
|
|
for contents.iter().advance |p| {
|
2013-06-21 12:38:10 -07:00
|
|
|
if p.filetype() == Some(~".rs") {
|
2013-06-14 18:16:24 -07:00
|
|
|
// should be able to do this w/o a process
|
|
|
|
if run::process_output("touch", [p.to_str()]).status != 0 {
|
2013-07-02 12:47:32 -07:00
|
|
|
let _ = cond.raise((pkg_src_dir.clone(), ~"Bad path"));
|
2013-06-14 18:16:24 -07:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Add a blank line at the end
|
|
|
|
fn frob_source_file(workspace: &Path, pkgid: &PkgId) {
|
|
|
|
use conditions::bad_path::cond;
|
|
|
|
let pkg_src_dir = workspace.push("src").push(pkgid.to_str());
|
2013-06-21 12:38:10 -07:00
|
|
|
let contents = os::list_dir_path(&pkg_src_dir);
|
2013-06-14 18:16:24 -07:00
|
|
|
let mut maybe_p = None;
|
2013-06-21 08:29:53 -04:00
|
|
|
for contents.iter().advance |p| {
|
2013-06-21 12:38:10 -07:00
|
|
|
if p.filetype() == Some(~".rs") {
|
2013-06-14 18:16:24 -07:00
|
|
|
maybe_p = Some(p);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
match maybe_p {
|
|
|
|
Some(p) => {
|
2013-07-21 18:33:29 +01:00
|
|
|
let w = io::file_writer(p, &[io::Append]);
|
2013-06-14 18:16:24 -07:00
|
|
|
match w {
|
2013-07-21 18:33:29 +01:00
|
|
|
Err(s) => { let _ = cond.raise((p.clone(), fmt!("Bad path: %s", s))); }
|
2013-06-14 18:16:24 -07:00
|
|
|
Ok(w) => w.write_line("")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
None => fail!(fmt!("frob_source_file failed to find a source file in %s",
|
|
|
|
pkg_src_dir.to_str()))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-25 23:46:26 -07:00
|
|
|
// FIXME(#7249): these tests fail on multi-platform builds, so for now they're
|
|
|
|
// only run one x86
|
2013-06-13 22:46:45 -07:00
|
|
|
|
2013-06-25 23:46:26 -07:00
|
|
|
#[test] #[ignore(cfg(target_arch = "x86"))]
|
2013-04-24 17:37:59 -07:00
|
|
|
fn test_make_dir_rwx() {
|
|
|
|
let temp = &os::tmpdir();
|
2013-05-27 18:04:00 -05:00
|
|
|
let dir = temp.push("quux");
|
2013-05-02 13:09:28 -07:00
|
|
|
assert!(!os::path_exists(&dir) ||
|
|
|
|
os::remove_dir_recursive(&dir));
|
|
|
|
debug!("Trying to make %s", dir.to_str());
|
2013-04-24 17:37:59 -07:00
|
|
|
assert!(make_dir_rwx(&dir));
|
|
|
|
assert!(os::path_is_dir(&dir));
|
|
|
|
assert!(is_rwx(&dir));
|
2013-05-02 13:09:28 -07:00
|
|
|
assert!(os::remove_dir_recursive(&dir));
|
2013-04-24 17:37:59 -07:00
|
|
|
}
|
|
|
|
|
2013-06-25 23:46:26 -07:00
|
|
|
#[test] #[ignore(cfg(target_arch = "x86"))]
|
2013-04-24 17:37:59 -07:00
|
|
|
fn test_install_valid() {
|
2013-05-27 17:45:16 -07:00
|
|
|
use path_util::installed_library_in_workspace;
|
|
|
|
|
2013-05-03 16:47:53 -07:00
|
|
|
let sysroot = test_sysroot();
|
|
|
|
debug!("sysroot = %s", sysroot.to_str());
|
|
|
|
let ctxt = fake_ctxt(Some(@sysroot));
|
2013-04-24 17:37:59 -07:00
|
|
|
let temp_pkg_id = fake_pkg();
|
2013-06-14 18:16:24 -07:00
|
|
|
let temp_workspace = mk_temp_workspace(&temp_pkg_id.local_path, &NoVersion).pop().pop();
|
|
|
|
debug!("temp_workspace = %s", temp_workspace.to_str());
|
2013-04-24 17:37:59 -07:00
|
|
|
// should have test, bench, lib, and main
|
2013-05-12 16:50:57 -04:00
|
|
|
ctxt.install(&temp_workspace, &temp_pkg_id);
|
2013-04-24 17:37:59 -07:00
|
|
|
// Check that all files exist
|
2013-05-12 16:50:57 -04:00
|
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, &temp_workspace);
|
2013-05-02 13:09:28 -07:00
|
|
|
debug!("exec = %s", exec.to_str());
|
2013-04-24 17:37:59 -07:00
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
2013-05-27 17:45:16 -07:00
|
|
|
|
|
|
|
let lib = installed_library_in_workspace(temp_pkg_id.short_name, &temp_workspace);
|
|
|
|
debug!("lib = %?", lib);
|
|
|
|
assert!(lib.map_default(false, |l| os::path_exists(l)));
|
|
|
|
assert!(lib.map_default(false, |l| is_rwx(l)));
|
|
|
|
|
2013-04-24 17:37:59 -07:00
|
|
|
// And that the test and bench executables aren't installed
|
2013-05-12 16:50:57 -04:00
|
|
|
assert!(!os::path_exists(&target_test_in_workspace(&temp_pkg_id, &temp_workspace)));
|
|
|
|
let bench = target_bench_in_workspace(&temp_pkg_id, &temp_workspace);
|
2013-05-02 13:09:28 -07:00
|
|
|
debug!("bench = %s", bench.to_str());
|
|
|
|
assert!(!os::path_exists(&bench));
|
2013-04-24 17:37:59 -07:00
|
|
|
}
|
|
|
|
|
2013-06-25 23:46:26 -07:00
|
|
|
#[test] #[ignore(cfg(target_arch = "x86"))]
|
2013-04-24 17:37:59 -07:00
|
|
|
fn test_install_invalid() {
|
|
|
|
use conditions::nonexistent_package::cond;
|
2013-05-02 13:09:28 -07:00
|
|
|
use cond1 = conditions::missing_pkg_files::cond;
|
2013-04-24 17:37:59 -07:00
|
|
|
|
2013-05-03 16:47:53 -07:00
|
|
|
let ctxt = fake_ctxt(None);
|
2013-04-24 17:37:59 -07:00
|
|
|
let pkgid = fake_pkg();
|
2013-05-02 13:09:28 -07:00
|
|
|
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;
|
2013-04-24 17:37:59 -07:00
|
|
|
}).in {
|
2013-05-02 13:09:28 -07:00
|
|
|
do cond.trap(|_| {
|
|
|
|
error_occurred = true;
|
2013-07-02 12:47:32 -07:00
|
|
|
temp_workspace.clone()
|
2013-05-02 13:09:28 -07:00
|
|
|
}).in {
|
2013-05-12 16:50:57 -04:00
|
|
|
ctxt.install(&temp_workspace, &pkgid);
|
2013-05-02 13:09:28 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
assert!(error_occurred && error1_occurred);
|
2013-04-26 12:24:15 -04:00
|
|
|
}
|
2013-05-03 16:47:53 -07:00
|
|
|
|
2013-07-09 18:28:00 -07:00
|
|
|
// Tests above should (maybe) be converted to shell out to rustpkg, too
|
|
|
|
|
2013-07-22 01:00:00 -04:00
|
|
|
// FIXME: #7956: temporarily disabled
|
|
|
|
#[ignore(cfg(target_arch = "x86"))]
|
2013-07-09 18:28:00 -07:00
|
|
|
fn test_install_git() {
|
2013-05-03 16:47:53 -07:00
|
|
|
let sysroot = test_sysroot();
|
|
|
|
debug!("sysroot = %s", sysroot.to_str());
|
2013-07-09 18:28:00 -07:00
|
|
|
let temp_pkg_id = git_repo_pkg();
|
|
|
|
let repo = init_git_repo(&Path(temp_pkg_id.local_path.to_str()));
|
|
|
|
let repo_subdir = repo.push("mockgithub.com").push("catamorphism").push("test_pkg");
|
|
|
|
writeFile(&repo_subdir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("lib.rs"),
|
|
|
|
"pub fn f() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("test.rs"),
|
|
|
|
"#[test] pub fn f() { (); }");
|
|
|
|
writeFile(&repo_subdir.push("bench.rs"),
|
|
|
|
"#[bench] pub fn f() { (); }");
|
|
|
|
add_git_tag(&repo_subdir, ~"0.1"); // this has the effect of committing the files
|
|
|
|
|
|
|
|
debug!("test_install_git: calling rustpkg install %s in %s",
|
|
|
|
temp_pkg_id.local_path.to_str(), repo.to_str());
|
2013-05-03 16:47:53 -07:00
|
|
|
// should have test, bench, lib, and main
|
2013-07-09 18:28:00 -07:00
|
|
|
command_line_test([~"install", temp_pkg_id.local_path.to_str()], &repo);
|
2013-05-03 16:47:53 -07:00
|
|
|
// Check that all files exist
|
2013-06-26 17:42:24 -07:00
|
|
|
debug!("Checking for files in %s", repo.to_str());
|
|
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, &repo);
|
2013-05-03 16:47:53 -07:00
|
|
|
debug!("exec = %s", exec.to_str());
|
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
2013-06-14 18:16:24 -07:00
|
|
|
let _built_lib =
|
2013-06-01 15:59:12 -07:00
|
|
|
built_library_in_workspace(&temp_pkg_id,
|
2013-06-26 17:42:24 -07:00
|
|
|
&repo).expect("test_install_git: built lib should exist");
|
|
|
|
let lib = target_library_in_workspace(&temp_pkg_id, &repo);
|
2013-05-03 16:47:53 -07:00
|
|
|
debug!("lib = %s", lib.to_str());
|
|
|
|
assert!(os::path_exists(&lib));
|
|
|
|
assert!(is_rwx(&lib));
|
2013-05-27 17:45:16 -07:00
|
|
|
let built_test = built_test_in_workspace(&temp_pkg_id,
|
2013-06-26 17:42:24 -07:00
|
|
|
&repo).expect("test_install_git: built test should exist");
|
2013-05-10 19:00:51 -07:00
|
|
|
assert!(os::path_exists(&built_test));
|
2013-05-14 17:46:52 -07:00
|
|
|
let built_bench = built_bench_in_workspace(&temp_pkg_id,
|
2013-06-26 17:42:24 -07:00
|
|
|
&repo).expect("test_install_git: built bench should exist");
|
2013-05-10 19:00:51 -07:00
|
|
|
assert!(os::path_exists(&built_bench));
|
2013-05-03 16:47:53 -07:00
|
|
|
// And that the test and bench executables aren't installed
|
2013-06-26 17:42:24 -07:00
|
|
|
let test = target_test_in_workspace(&temp_pkg_id, &repo);
|
2013-05-10 19:00:51 -07:00
|
|
|
assert!(!os::path_exists(&test));
|
|
|
|
debug!("test = %s", test.to_str());
|
2013-06-26 17:42:24 -07:00
|
|
|
let bench = target_bench_in_workspace(&temp_pkg_id, &repo);
|
2013-05-03 16:47:53 -07:00
|
|
|
debug!("bench = %s", bench.to_str());
|
|
|
|
assert!(!os::path_exists(&bench));
|
2013-05-12 16:50:57 -04:00
|
|
|
}
|
2013-05-14 17:46:52 -07:00
|
|
|
|
2013-06-25 23:46:26 -07:00
|
|
|
#[test] #[ignore(cfg(target_arch = "x86"))]
|
2013-05-14 17:46:52 -07:00
|
|
|
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)
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2013-07-09 18:28:00 -07:00
|
|
|
let whatever = PkgId::new("foo", &os::getcwd());
|
2013-05-14 17:46:52 -07:00
|
|
|
|
2013-06-14 18:16:24 -07:00
|
|
|
assert_eq!(~"foo-0.1", whatever.to_str());
|
|
|
|
assert!("github.com/catamorphism/test_pkg-0.1" ==
|
2013-07-09 18:28:00 -07:00
|
|
|
PkgId::new("github.com/catamorphism/test-pkg", &os::getcwd()).to_str());
|
2013-05-14 17:46:52 -07:00
|
|
|
|
|
|
|
do cond.trap(|(p, e)| {
|
|
|
|
assert!("" == p.to_str());
|
|
|
|
assert!("0-length pkgid" == e);
|
2013-07-02 12:47:32 -07:00
|
|
|
whatever.clone()
|
2013-05-14 17:46:52 -07:00
|
|
|
}).in {
|
2013-07-09 18:28:00 -07:00
|
|
|
let x = PkgId::new("", &os::getcwd());
|
2013-06-14 18:16:24 -07:00
|
|
|
assert_eq!(~"foo-0.1", x.to_str());
|
2013-05-14 17:46:52 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
do cond.trap(|(p, e)| {
|
2013-05-18 22:02:45 -04:00
|
|
|
assert_eq!(p.to_str(), os::make_absolute(&Path("foo/bar/quux")).to_str());
|
2013-05-14 17:46:52 -07:00
|
|
|
assert!("absolute pkgid" == e);
|
2013-07-02 12:47:32 -07:00
|
|
|
whatever.clone()
|
2013-05-14 17:46:52 -07:00
|
|
|
}).in {
|
2013-07-09 18:28:00 -07:00
|
|
|
let z = PkgId::new(os::make_absolute(&Path("foo/bar/quux")).to_str(),
|
|
|
|
&os::getcwd());
|
2013-06-14 18:16:24 -07:00
|
|
|
assert_eq!(~"foo-0.1", z.to_str());
|
2013-05-14 17:46:52 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2013-05-30 12:03:21 -07:00
|
|
|
|
2013-07-22 01:00:00 -04:00
|
|
|
// FIXME: #7956: temporarily disabled
|
|
|
|
#[ignore(cfg(target_arch = "x86"))]
|
2013-05-30 12:03:21 -07:00
|
|
|
fn test_package_version() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let local_path = "mockgithub.com/catamorphism/test_pkg_version";
|
|
|
|
let repo = init_git_repo(&Path(local_path));
|
|
|
|
let repo_subdir = repo.push("mockgithub.com").push("catamorphism").push("test_pkg_version");
|
|
|
|
debug!("Writing files in: %s", repo_subdir.to_str());
|
|
|
|
writeFile(&repo_subdir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("lib.rs"),
|
|
|
|
"pub fn f() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("test.rs"),
|
|
|
|
"#[test] pub fn f() { (); }");
|
|
|
|
writeFile(&repo_subdir.push("bench.rs"),
|
|
|
|
"#[bench] pub fn f() { (); }");
|
|
|
|
add_git_tag(&repo_subdir, ~"0.4");
|
|
|
|
|
|
|
|
let temp_pkg_id = PkgId::new("mockgithub.com/catamorphism/test_pkg_version", &repo);
|
2013-05-30 12:03:21 -07:00
|
|
|
match temp_pkg_id.version {
|
2013-06-01 15:59:12 -07:00
|
|
|
ExactRevision(~"0.4") => (),
|
|
|
|
_ => fail!(fmt!("test_package_version: package version was %?, expected Some(0.4)",
|
|
|
|
temp_pkg_id.version))
|
|
|
|
}
|
2013-07-09 18:28:00 -07:00
|
|
|
// This should look at the prefix, clone into a workspace, then build.
|
|
|
|
command_line_test([~"install", ~"mockgithub.com/catamorphism/test_pkg_version"],
|
|
|
|
&repo);
|
|
|
|
assert!(match built_library_in_workspace(&temp_pkg_id,
|
2013-06-26 17:42:24 -07:00
|
|
|
&repo) {
|
2013-06-01 15:59:12 -07:00
|
|
|
Some(p) => p.to_str().ends_with(fmt!("0.4%s", os::consts::DLL_SUFFIX)),
|
|
|
|
None => false
|
|
|
|
});
|
2013-06-26 17:42:24 -07:00
|
|
|
assert!(built_executable_in_workspace(&temp_pkg_id, &repo)
|
|
|
|
== Some(repo.push("build").
|
2013-07-09 18:28:00 -07:00
|
|
|
push("mockgithub.com").
|
2013-06-01 15:59:12 -07:00
|
|
|
push("catamorphism").
|
|
|
|
push("test_pkg_version").
|
|
|
|
push("test_pkg_version")));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_package_request_version() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let local_path = "mockgithub.com/catamorphism/test_pkg_version";
|
|
|
|
let repo = init_git_repo(&Path(local_path));
|
|
|
|
let repo_subdir = repo.push("mockgithub.com").push("catamorphism").push("test_pkg_version");
|
|
|
|
debug!("Writing files in: %s", repo_subdir.to_str());
|
|
|
|
writeFile(&repo_subdir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("lib.rs"),
|
|
|
|
"pub fn f() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("test.rs"),
|
|
|
|
"#[test] pub fn f() { (); }");
|
|
|
|
writeFile(&repo_subdir.push("bench.rs"),
|
|
|
|
"#[bench] pub fn f() { (); }");
|
|
|
|
writeFile(&repo_subdir.push("version-0.3-file.txt"), "hi");
|
|
|
|
add_git_tag(&repo_subdir, ~"0.3");
|
|
|
|
writeFile(&repo_subdir.push("version-0.4-file.txt"), "hello");
|
|
|
|
add_git_tag(&repo_subdir, ~"0.4");
|
|
|
|
|
|
|
|
command_line_test([~"install", fmt!("%s#0.3", local_path)], &repo);
|
|
|
|
|
|
|
|
assert!(match installed_library_in_workspace("test_pkg_version", &repo.push(".rust")) {
|
2013-06-01 15:59:12 -07:00
|
|
|
Some(p) => {
|
|
|
|
debug!("installed: %s", p.to_str());
|
|
|
|
p.to_str().ends_with(fmt!("0.3%s", os::consts::DLL_SUFFIX))
|
|
|
|
}
|
|
|
|
None => false
|
|
|
|
});
|
2013-07-09 18:28:00 -07:00
|
|
|
let temp_pkg_id = PkgId::new("mockgithub.com/catamorphism/test_pkg_version#0.3", &repo);
|
|
|
|
assert!(target_executable_in_workspace(&temp_pkg_id, &repo.push(".rust"))
|
|
|
|
== repo.push(".rust").push("bin").push("test_pkg_version"));
|
2013-06-01 15:59:12 -07:00
|
|
|
|
2013-07-09 18:28:00 -07:00
|
|
|
assert!(os::path_exists(&repo.push(".rust").push("src")
|
|
|
|
.push("mockgithub.com").push("catamorphism")
|
|
|
|
.push("test_pkg_version-0.3")
|
|
|
|
.push("version-0.3-file.txt")));
|
|
|
|
assert!(!os::path_exists(&repo.push(".rust").push("src")
|
|
|
|
.push("mockgithub.com").push("catamorphism")
|
|
|
|
.push("test_pkg_version-0.3")
|
|
|
|
.push("version-0.4-file.txt")));
|
2013-05-30 12:03:21 -07:00
|
|
|
}
|
2013-06-14 18:16:24 -07:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore (reason = "http-client not ported to rustpkg yet")]
|
|
|
|
fn rustpkg_install_url_2() {
|
|
|
|
let temp_dir = mkdtemp(&os::tmpdir(), "rustpkg_install_url_2").expect("rustpkg_install_url_2");
|
|
|
|
command_line_test([~"install", ~"github.com/mozilla-servo/rust-http-client"],
|
|
|
|
&temp_dir);
|
|
|
|
}
|
|
|
|
|
2013-07-22 01:00:00 -04:00
|
|
|
// FIXME: #7956: temporarily disabled
|
2013-07-24 18:42:14 -07:00
|
|
|
#[test]
|
2013-06-14 18:16:24 -07:00
|
|
|
fn rustpkg_library_target() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let foo_repo = init_git_repo(&Path("foo"));
|
|
|
|
let package_dir = foo_repo.push("foo");
|
|
|
|
|
|
|
|
debug!("Writing files in: %s", package_dir.to_str());
|
|
|
|
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() { (); }");
|
|
|
|
|
|
|
|
add_git_tag(&package_dir, ~"1.0");
|
2013-06-14 18:16:24 -07:00
|
|
|
command_line_test([~"install", ~"foo"], &foo_repo);
|
2013-06-26 17:42:24 -07:00
|
|
|
assert_lib_exists(&foo_repo, "foo", ExactRevision(~"1.0"));
|
2013-06-14 18:16:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rustpkg_local_pkg() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let dir = create_local_package(&PkgId::new("foo", &os::getcwd()));
|
2013-06-14 18:16:24 -07:00
|
|
|
command_line_test([~"install", ~"foo"], &dir);
|
|
|
|
assert_executable_exists(&dir, "foo");
|
|
|
|
}
|
|
|
|
|
2013-07-24 18:42:14 -07:00
|
|
|
// FIXME: #7956: temporarily disabled
|
|
|
|
// Failing on dist-linux bot
|
2013-06-25 22:26:22 -07:00
|
|
|
#[test]
|
2013-07-24 18:42:14 -07:00
|
|
|
#[ignore]
|
2013-06-25 22:26:22 -07:00
|
|
|
fn package_script_with_default_build() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let dir = create_local_package(&PkgId::new("fancy-lib", &os::getcwd()));
|
2013-06-25 22:26:22 -07:00
|
|
|
debug!("dir = %s", dir.to_str());
|
|
|
|
let source = test_sysroot().pop().pop().pop().push("src").push("librustpkg").
|
|
|
|
push("testsuite").push("pass").push("src").push("fancy-lib").push("pkg.rs");
|
|
|
|
debug!("package_script_with_default_build: %s", source.to_str());
|
|
|
|
if !os::copy_file(&source,
|
|
|
|
& dir.push("src").push("fancy_lib-0.1").push("pkg.rs")) {
|
|
|
|
fail!("Couldn't copy file");
|
|
|
|
}
|
|
|
|
command_line_test([~"install", ~"fancy-lib"], &dir);
|
2013-07-09 18:28:00 -07:00
|
|
|
assert_lib_exists(&dir, "fancy-lib", NoVersion);
|
2013-06-25 22:26:22 -07:00
|
|
|
assert!(os::path_exists(&dir.push("build").push("fancy_lib").push("generated.rs")));
|
|
|
|
}
|
|
|
|
|
2013-06-26 17:42:24 -07:00
|
|
|
#[test]
|
|
|
|
fn rustpkg_build_no_arg() {
|
|
|
|
let tmp = mkdtemp(&os::tmpdir(), "rustpkg_build_no_arg").expect("rustpkg_build_no_arg failed");
|
|
|
|
let package_dir = tmp.push("src").push("foo");
|
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
|
|
|
|
writeFile(&package_dir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
debug!("build_no_arg: dir = %s", package_dir.to_str());
|
|
|
|
command_line_test([~"build"], &package_dir);
|
|
|
|
assert_built_executable_exists(&tmp, "foo");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rustpkg_install_no_arg() {
|
|
|
|
let tmp = mkdtemp(&os::tmpdir(),
|
|
|
|
"rustpkg_install_no_arg").expect("rustpkg_build_no_arg failed");
|
|
|
|
let package_dir = tmp.push("src").push("foo");
|
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
writeFile(&package_dir.push("lib.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
debug!("install_no_arg: dir = %s", package_dir.to_str());
|
|
|
|
command_line_test([~"install"], &package_dir);
|
|
|
|
assert_lib_exists(&tmp, "foo", NoVersion);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rustpkg_clean_no_arg() {
|
|
|
|
let tmp = mkdtemp(&os::tmpdir(), "rustpkg_clean_no_arg").expect("rustpkg_clean_no_arg failed");
|
|
|
|
let package_dir = tmp.push("src").push("foo");
|
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
|
|
|
|
writeFile(&package_dir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
debug!("clean_no_arg: dir = %s", package_dir.to_str());
|
|
|
|
command_line_test([~"build"], &package_dir);
|
|
|
|
assert_built_executable_exists(&tmp, "foo");
|
|
|
|
command_line_test([~"clean"], &package_dir);
|
|
|
|
assert!(!built_executable_in_workspace(&PkgId::new("foo", &package_dir),
|
|
|
|
&tmp).map_default(false, |m| { os::path_exists(m) }));
|
|
|
|
}
|
|
|
|
|
2013-06-14 18:16:24 -07:00
|
|
|
#[test]
|
2013-07-24 18:42:14 -07:00
|
|
|
#[ignore (reason = "Specifying env doesn't work -- see #8028")]
|
2013-06-14 18:16:24 -07:00
|
|
|
fn rust_path_test() {
|
2013-06-25 19:49:01 -07:00
|
|
|
let dir_for_path = mkdtemp(&os::tmpdir(), "more_rust").expect("rust_path_test failed");
|
|
|
|
let dir = mk_workspace(&dir_for_path, &normalize(RemotePath(Path("foo"))), &NoVersion);
|
|
|
|
debug!("dir = %s", dir.to_str());
|
2013-06-26 17:42:24 -07:00
|
|
|
writeFile(&dir.push("main.rs"), "fn main() { let _x = (); }");
|
2013-06-25 19:49:01 -07:00
|
|
|
|
|
|
|
let cwd = os::getcwd();
|
|
|
|
debug!("cwd = %s", cwd.to_str());
|
2013-07-24 18:42:14 -07:00
|
|
|
debug!("Running command: cd %s; RUST_LOG=rustpkg RUST_PATH=%s rustpkg install foo",
|
|
|
|
cwd.to_str(), dir_for_path.to_str());
|
2013-06-25 19:49:01 -07:00
|
|
|
let mut prog = run::Process::new("rustpkg",
|
|
|
|
[~"install", ~"foo"],
|
2013-07-24 18:42:14 -07:00
|
|
|
run::ProcessOptions { env: Some(&[(~"RUST_LOG",
|
|
|
|
~"rustpkg"),
|
|
|
|
(~"RUST_PATH",
|
2013-06-25 19:49:01 -07:00
|
|
|
dir_for_path.to_str())]),
|
|
|
|
dir: Some(&cwd),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
prog.finish_with_output();
|
|
|
|
assert_executable_exists(&dir_for_path, "foo");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_contents() {
|
2013-07-17 18:59:29 -07:00
|
|
|
use std::unstable::change_dir_locked;
|
|
|
|
|
2013-06-25 19:49:01 -07:00
|
|
|
let dir = mkdtemp(&os::tmpdir(), "rust_path").expect("rust_path_contents failed");
|
|
|
|
let abc = &dir.push("A").push("B").push("C");
|
2013-07-01 13:51:13 +10:00
|
|
|
assert!(os::mkdir_recursive(&abc.push(".rust"), U_RWX));
|
|
|
|
assert!(os::mkdir_recursive(&abc.pop().push(".rust"), U_RWX));
|
|
|
|
assert!(os::mkdir_recursive(&abc.pop().pop().push(".rust"), U_RWX));
|
2013-07-17 18:59:29 -07:00
|
|
|
assert!(do change_dir_locked(&dir.push("A").push("B").push("C")) {
|
2013-06-25 19:49:01 -07:00
|
|
|
let p = rust_path();
|
|
|
|
let cwd = os::getcwd().push(".rust");
|
|
|
|
let parent = cwd.pop().pop().push(".rust");
|
|
|
|
let grandparent = cwd.pop().pop().pop().push(".rust");
|
2013-06-29 02:08:32 +10:00
|
|
|
assert!(p.contains(&cwd));
|
|
|
|
assert!(p.contains(&parent));
|
|
|
|
assert!(p.contains(&grandparent));
|
2013-06-25 19:49:01 -07:00
|
|
|
for p.iter().advance() |a_path| {
|
|
|
|
assert!(!a_path.components.is_empty());
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_parse() {
|
|
|
|
os::setenv("RUST_PATH", "/a/b/c:/d/e/f:/g/h/i");
|
|
|
|
let paths = rust_path();
|
2013-06-29 02:08:32 +10:00
|
|
|
assert!(paths.contains(&Path("/g/h/i")));
|
|
|
|
assert!(paths.contains(&Path("/d/e/f")));
|
|
|
|
assert!(paths.contains(&Path("/a/b/c")));
|
2013-06-25 19:49:01 -07:00
|
|
|
os::unsetenv("RUST_PATH");
|
2013-06-14 18:16:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-07-11 18:20:31 -07:00
|
|
|
fn test_list() {
|
|
|
|
let dir = mkdtemp(&os::tmpdir(), "test_list").expect("test_list failed");
|
2013-07-09 18:28:00 -07:00
|
|
|
let foo = PkgId::new("foo", &dir);
|
2013-07-11 18:20:31 -07:00
|
|
|
create_local_package_in(&foo, &dir);
|
2013-07-09 18:28:00 -07:00
|
|
|
let bar = PkgId::new("bar", &dir);
|
2013-07-11 18:20:31 -07:00
|
|
|
create_local_package_in(&bar, &dir);
|
2013-07-09 18:28:00 -07:00
|
|
|
let quux = PkgId::new("quux", &dir);
|
2013-07-11 18:20:31 -07:00
|
|
|
create_local_package_in(&quux, &dir);
|
|
|
|
|
2013-06-26 17:42:24 -07:00
|
|
|
// NOTE Not really great output, though...
|
|
|
|
// NOTE do any tests need to be unignored?
|
2013-07-11 18:20:31 -07:00
|
|
|
command_line_test([~"install", ~"foo"], &dir);
|
|
|
|
let env_arg = ~[(~"RUST_PATH", dir.to_str())];
|
2013-06-26 17:42:24 -07:00
|
|
|
debug!("RUST_PATH = %s", dir.to_str());
|
2013-07-11 18:20:31 -07:00
|
|
|
let list_output = command_line_test_output_with_env([~"list"], env_arg.clone());
|
2013-06-26 17:42:24 -07:00
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("libfoo_")));
|
2013-07-11 18:20:31 -07:00
|
|
|
|
|
|
|
command_line_test([~"install", ~"bar"], &dir);
|
|
|
|
let list_output = command_line_test_output_with_env([~"list"], env_arg.clone());
|
2013-06-26 17:42:24 -07:00
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("libfoo_")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("libbar_")));
|
2013-07-11 18:20:31 -07:00
|
|
|
|
|
|
|
command_line_test([~"install", ~"quux"], &dir);
|
|
|
|
let list_output = command_line_test_output_with_env([~"list"], env_arg);
|
2013-06-26 17:42:24 -07:00
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("libfoo_")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("libbar_")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("libquux_")));
|
2013-07-11 18:20:31 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-06-14 18:16:24 -07:00
|
|
|
fn install_remove() {
|
|
|
|
let dir = mkdtemp(&os::tmpdir(), "install_remove").expect("install_remove");
|
2013-07-09 18:28:00 -07:00
|
|
|
let foo = PkgId::new("foo", &dir);
|
|
|
|
let bar = PkgId::new("bar", &dir);
|
|
|
|
let quux = PkgId::new("quux", &dir);
|
2013-06-14 18:16:24 -07:00
|
|
|
create_local_package_in(&foo, &dir);
|
|
|
|
create_local_package_in(&bar, &dir);
|
|
|
|
create_local_package_in(&quux, &dir);
|
2013-07-11 18:20:31 -07:00
|
|
|
let rust_path_to_use = ~[(~"RUST_PATH", dir.to_str())];
|
2013-06-14 18:16:24 -07:00
|
|
|
command_line_test([~"install", ~"foo"], &dir);
|
|
|
|
command_line_test([~"install", ~"bar"], &dir);
|
|
|
|
command_line_test([~"install", ~"quux"], &dir);
|
2013-07-11 18:20:31 -07:00
|
|
|
let list_output = command_line_test_output_with_env([~"list"], rust_path_to_use.clone());
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("foo")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("bar")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("quux")));
|
|
|
|
command_line_test([~"uninstall", ~"foo"], &dir);
|
|
|
|
let list_output = command_line_test_output_with_env([~"list"], rust_path_to_use.clone());
|
|
|
|
assert!(!list_output.iter().any(|x| x.starts_with("foo")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("bar")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("quux")));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn install_check_duplicates() {
|
|
|
|
// should check that we don't install two packages with the same full name *and* version
|
|
|
|
// ("Is already installed -- doing nothing")
|
|
|
|
// check invariant that there are no dups in the pkg database
|
|
|
|
let dir = mkdtemp(&os::tmpdir(), "install_remove").expect("install_remove");
|
2013-07-09 18:28:00 -07:00
|
|
|
let foo = PkgId::new("foo", &dir);
|
2013-07-11 18:20:31 -07:00
|
|
|
create_local_package_in(&foo, &dir);
|
|
|
|
|
|
|
|
command_line_test([~"install", ~"foo"], &dir);
|
|
|
|
command_line_test([~"install", ~"foo"], &dir);
|
|
|
|
let mut contents = ~[];
|
|
|
|
let check_dups = |p: &PkgId| {
|
|
|
|
if contents.contains(p) {
|
2013-06-26 17:42:24 -07:00
|
|
|
fail!("package %s appears in `list` output more than once", p.local_path.to_str());
|
2013-07-11 18:20:31 -07:00
|
|
|
}
|
|
|
|
else {
|
2013-07-10 14:43:25 -07:00
|
|
|
contents.push((*p).clone());
|
2013-07-11 18:20:31 -07:00
|
|
|
}
|
|
|
|
false
|
|
|
|
};
|
|
|
|
list_installed_packages(check_dups);
|
2013-06-14 18:16:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "Workcache not yet implemented -- see #7075")]
|
|
|
|
fn no_rebuilding() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let p_id = PkgId::new("foo", &os::getcwd());
|
2013-06-14 18:16:24 -07:00
|
|
|
let workspace = create_local_package(&p_id);
|
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let date = datestamp(&built_library_in_workspace(&p_id,
|
|
|
|
&workspace).expect("no_rebuilding"));
|
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let newdate = datestamp(&built_library_in_workspace(&p_id,
|
|
|
|
&workspace).expect("no_rebuilding (2)"));
|
|
|
|
assert_eq!(date, newdate);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "Workcache not yet implemented -- see #7075")]
|
|
|
|
fn no_rebuilding_dep() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let p_id = PkgId::new("foo", &os::getcwd());
|
|
|
|
let dep_id = PkgId::new("bar", &os::getcwd());
|
2013-06-14 18:16:24 -07:00
|
|
|
let workspace = create_local_package_with_dep(&p_id, &dep_id);
|
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let bar_date = datestamp(&lib_output_file_name(&workspace,
|
|
|
|
".rust",
|
|
|
|
"bar"));
|
|
|
|
let foo_date = datestamp(&output_file_name(&workspace, "foo"));
|
|
|
|
assert!(bar_date < foo_date);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn do_rebuild_dep_dates_change() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let p_id = PkgId::new("foo", &os::getcwd());
|
|
|
|
let dep_id = PkgId::new("bar", &os::getcwd());
|
2013-06-14 18:16:24 -07:00
|
|
|
let workspace = create_local_package_with_dep(&p_id, &dep_id);
|
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let bar_date = datestamp(&lib_output_file_name(&workspace, "build", "bar"));
|
2013-06-21 12:38:10 -07:00
|
|
|
touch_source_file(&workspace, &dep_id);
|
2013-06-14 18:16:24 -07:00
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let new_bar_date = datestamp(&lib_output_file_name(&workspace, "build", "bar"));
|
|
|
|
assert!(new_bar_date > bar_date);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn do_rebuild_dep_only_contents_change() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let p_id = PkgId::new("foo", &os::getcwd());
|
|
|
|
let dep_id = PkgId::new("bar", &os::getcwd());
|
2013-06-14 18:16:24 -07:00
|
|
|
let workspace = create_local_package_with_dep(&p_id, &dep_id);
|
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let bar_date = datestamp(&lib_output_file_name(&workspace, "build", "bar"));
|
|
|
|
frob_source_file(&workspace, &dep_id);
|
|
|
|
// should adjust the datestamp
|
|
|
|
command_line_test([~"build", ~"foo"], &workspace);
|
|
|
|
let new_bar_date = datestamp(&lib_output_file_name(&workspace, "build", "bar"));
|
|
|
|
assert!(new_bar_date > bar_date);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_versions() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let workspace = create_local_package(&PkgId::new("foo#0.1", &os::getcwd()));
|
|
|
|
create_local_package(&PkgId::new("foo#0.2", &os::getcwd()));
|
2013-06-14 18:16:24 -07:00
|
|
|
command_line_test([~"install", ~"foo#0.1"], &workspace);
|
|
|
|
let output = command_line_test_output([~"list"]);
|
|
|
|
// make sure output includes versions
|
2013-07-04 22:13:26 -04:00
|
|
|
assert!(!output.iter().any(|x| x == &~"foo#0.2"));
|
2013-06-14 18:16:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "do not yet implemented")]
|
|
|
|
fn test_build_hooks() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let workspace = create_local_package_with_custom_build_hook(&PkgId::new("foo", &os::getcwd()),
|
|
|
|
"frob");
|
2013-06-14 18:16:24 -07:00
|
|
|
command_line_test([~"do", ~"foo", ~"frob"], &workspace);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "info not yet implemented")]
|
|
|
|
fn test_info() {
|
|
|
|
let expected_info = ~"package foo"; // fill in
|
2013-07-09 18:28:00 -07:00
|
|
|
let workspace = create_local_package(&PkgId::new("foo", &os::getcwd()));
|
2013-06-14 18:16:24 -07:00
|
|
|
let output = command_line_test([~"info", ~"foo"], &workspace);
|
|
|
|
assert_eq!(str::from_bytes(output.output), expected_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "test not yet implemented")]
|
|
|
|
fn test_rustpkg_test() {
|
|
|
|
let expected_results = ~"1 out of 1 tests passed"; // fill in
|
2013-07-09 18:28:00 -07:00
|
|
|
let workspace = create_local_package_with_test(&PkgId::new("foo", &os::getcwd()));
|
2013-06-14 18:16:24 -07:00
|
|
|
let output = command_line_test([~"test", ~"foo"], &workspace);
|
|
|
|
assert_eq!(str::from_bytes(output.output), expected_results);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_uninstall() {
|
2013-07-09 18:28:00 -07:00
|
|
|
let workspace = create_local_package(&PkgId::new("foo", &os::getcwd()));
|
2013-06-14 18:16:24 -07:00
|
|
|
let _output = command_line_test([~"info", ~"foo"], &workspace);
|
|
|
|
command_line_test([~"uninstall", ~"foo"], &workspace);
|
|
|
|
let output = command_line_test([~"list"], &workspace);
|
|
|
|
assert!(!str::from_bytes(output.output).contains("foo"));
|
|
|
|
}
|
2013-07-24 18:42:14 -07:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_non_numeric_tag() {
|
|
|
|
let temp_pkg_id = git_repo_pkg();
|
|
|
|
let repo = init_git_repo(&Path(temp_pkg_id.local_path.to_str()));
|
|
|
|
let repo_subdir = repo.push("mockgithub.com").push("catamorphism").push("test_pkg");
|
|
|
|
writeFile(&repo_subdir.push("foo"), "foo");
|
|
|
|
writeFile(&repo_subdir.push("lib.rs"),
|
|
|
|
"pub fn f() { let _x = (); }");
|
|
|
|
add_git_tag(&repo_subdir, ~"testbranch");
|
|
|
|
writeFile(&repo_subdir.push("testbranch_only"), "hello");
|
|
|
|
add_git_tag(&repo_subdir, ~"another_tag");
|
|
|
|
writeFile(&repo_subdir.push("not_on_testbranch_only"), "bye bye");
|
|
|
|
add_all_and_commit(&repo_subdir);
|
|
|
|
|
|
|
|
|
|
|
|
command_line_test([~"install", fmt!("%s#testbranch", temp_pkg_id.remote_path.to_str())],
|
|
|
|
&repo);
|
|
|
|
let file1 = repo.push_many(["mockgithub.com", "catamorphism",
|
|
|
|
"test_pkg", "testbranch_only"]);
|
|
|
|
let file2 = repo.push_many(["mockgithub.com", "catamorphism", "test_pkg",
|
|
|
|
"master_only"]);
|
2013-07-26 12:31:53 -07:00
|
|
|
assert!(os::path_exists(&file1));
|
2013-07-24 18:42:14 -07:00
|
|
|
assert!(!os::path_exists(&file2));
|
|
|
|
}
|