2013-04-12 18:15:40 -05: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 19:37:59 -05:00
|
|
|
|
2013-09-10 13:41:05 -05:00
|
|
|
use context::{BuildContext, Context, RustcFlags};
|
2013-10-05 15:40:01 -05:00
|
|
|
use std::{io, os, run, str, task};
|
2013-09-06 22:29:16 -05:00
|
|
|
use extra::arc::Arc;
|
|
|
|
use extra::arc::RWArc;
|
2013-10-11 08:55:37 -05:00
|
|
|
use extra::tempfile::TempDir;
|
2013-09-09 00:00:49 -05:00
|
|
|
use extra::workcache;
|
|
|
|
use extra::workcache::{Database, Logger};
|
2013-09-06 22:29:16 -05:00
|
|
|
use extra::treemap::TreeMap;
|
2013-09-10 13:41:05 -05:00
|
|
|
use extra::getopts::groups::getopts;
|
2013-06-28 17:32:26 -05:00
|
|
|
use std::run::ProcessOutput;
|
2013-07-11 20:20:31 -05:00
|
|
|
use installed_packages::list_installed_packages;
|
2013-06-14 20:16:24 -05:00
|
|
|
use package_id::{PkgId};
|
2013-07-24 20:42:14 -05:00
|
|
|
use version::{ExactRevision, NoVersion, Version, Tagged};
|
2013-08-27 07:45:40 -05:00
|
|
|
use path_util::{target_executable_in_workspace, target_test_in_workspace,
|
|
|
|
target_bench_in_workspace, make_dir_rwx, U_RWX,
|
|
|
|
library_in_workspace, installed_library_in_workspace,
|
2013-06-01 17:59:12 -05:00
|
|
|
built_bench_in_workspace, built_test_in_workspace,
|
2013-10-05 15:40:01 -05:00
|
|
|
built_library_in_workspace, built_executable_in_workspace, target_build_dir,
|
|
|
|
chmod_read_only};
|
2013-09-10 13:41:05 -05:00
|
|
|
use rustc::back::link::get_cc_prog;
|
2013-07-31 15:47:32 -05:00
|
|
|
use rustc::metadata::filesearch::rust_path;
|
2013-09-10 13:41:05 -05:00
|
|
|
use rustc::driver::driver::{build_session, build_session_options, host_triple, optgroups};
|
|
|
|
use syntax::diagnostic;
|
2013-06-14 20:16:24 -05:00
|
|
|
use target::*;
|
2013-09-06 22:29:16 -05:00
|
|
|
use package_source::PkgSrc;
|
2013-10-05 15:40:01 -05:00
|
|
|
use source_control::{CheckedOutSources, DirToUse, safe_git_clone};
|
2013-09-16 21:27:09 -05:00
|
|
|
use util::datestamp;
|
2013-04-24 19:37:59 -05:00
|
|
|
|
2013-09-09 00:00:49 -05:00
|
|
|
fn fake_ctxt(sysroot: Path, workspace: &Path) -> BuildContext {
|
|
|
|
let context = workcache::Context::new(
|
|
|
|
RWArc::new(Database::new(workspace.push("rustpkg_db.json"))),
|
|
|
|
RWArc::new(Logger::new()),
|
|
|
|
Arc::new(TreeMap::new()));
|
|
|
|
BuildContext {
|
|
|
|
workcache_context: context,
|
|
|
|
context: Context {
|
2013-09-10 13:41:05 -05:00
|
|
|
cfgs: ~[],
|
|
|
|
rustc_flags: RustcFlags::default(),
|
|
|
|
|
2013-09-06 22:29:16 -05:00
|
|
|
use_rust_path_hack: false,
|
2013-09-09 00:00:49 -05:00
|
|
|
sysroot: sysroot
|
2013-09-06 22:29:16 -05:00
|
|
|
}
|
2013-04-24 19:37:59 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fake_pkg() -> PkgId {
|
2013-05-10 21:00:51 -05:00
|
|
|
let sn = ~"bogus";
|
2013-04-24 19:37:59 -05:00
|
|
|
PkgId {
|
2013-08-02 18:59:58 -05:00
|
|
|
path: Path(sn),
|
2013-05-10 21:00:51 -05:00
|
|
|
short_name: sn,
|
2013-06-01 17:59:12 -05:00
|
|
|
version: NoVersion
|
2013-04-24 19:37:59 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-09 20:28:00 -05:00
|
|
|
fn git_repo_pkg() -> PkgId {
|
2013-05-03 18:47:53 -05:00
|
|
|
PkgId {
|
2013-08-02 18:59:58 -05:00
|
|
|
path: Path("mockgithub.com/catamorphism/test-pkg"),
|
|
|
|
short_name: ~"test-pkg",
|
2013-06-01 17:59:12 -05:00
|
|
|
version: NoVersion
|
2013-05-30 14:03:21 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-24 20:42:14 -05:00
|
|
|
fn git_repo_pkg_with_tag(a_tag: ~str) -> PkgId {
|
|
|
|
PkgId {
|
2013-08-02 18:59:58 -05:00
|
|
|
path: Path("mockgithub.com/catamorphism/test-pkg"),
|
|
|
|
short_name: ~"test-pkg",
|
2013-07-24 20:42:14 -05:00
|
|
|
version: Tagged(a_tag)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-27 19:45:16 -05:00
|
|
|
fn writeFile(file_path: &Path, contents: &str) {
|
2013-07-26 20:36:51 -05:00
|
|
|
let out = io::file_writer(file_path, [io::Create, io::Truncate]).unwrap();
|
2013-05-02 15:09:28 -05:00
|
|
|
out.write_line(contents);
|
|
|
|
}
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
fn mk_emptier_workspace(tag: &str) -> TempDir {
|
|
|
|
let workspace = TempDir::new(tag).expect("couldn't create temp dir");
|
|
|
|
let package_dir = workspace.path().push("src");
|
2013-10-05 15:40:01 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
workspace
|
|
|
|
}
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
fn mk_empty_workspace(short_name: &Path, version: &Version, tag: &str) -> TempDir {
|
|
|
|
let workspace_dir = TempDir::new(tag).expect("couldn't create temp dir");
|
|
|
|
mk_workspace(workspace_dir.path(), short_name, version);
|
2013-06-14 20:16:24 -05:00
|
|
|
workspace_dir
|
|
|
|
}
|
|
|
|
|
2013-08-02 18:59:58 -05:00
|
|
|
fn mk_workspace(workspace: &Path, short_name: &Path, version: &Version) -> Path {
|
2013-05-14 19:46:52 -05:00
|
|
|
// include version number in directory name
|
2013-09-28 01:37:25 -05:00
|
|
|
let package_dir = workspace.push_many([~"src", format!("{}-{}",
|
|
|
|
short_name.to_str(), version.to_str())]);
|
2013-06-30 22:51:13 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
2013-06-14 20:16:24 -05:00
|
|
|
package_dir
|
2013-06-01 17:59:12 -05:00
|
|
|
}
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
fn mk_temp_workspace(short_name: &Path, version: &Version) -> (TempDir, Path) {
|
|
|
|
let workspace_dir = mk_empty_workspace(short_name, version, "temp_workspace");
|
|
|
|
let package_dir = workspace_dir.path().push_many([~"src",
|
|
|
|
format!("{}-{}",
|
|
|
|
short_name.to_str(),
|
|
|
|
version.to_str())]);
|
2013-06-01 17:59:12 -05:00
|
|
|
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Created {} and does it exist? {:?}", package_dir.to_str(),
|
2013-05-27 19:45:16 -05:00
|
|
|
os::path_is_dir(&package_dir));
|
2013-05-02 15:09:28 -05:00
|
|
|
// Create main, lib, test, and bench files
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("mk_workspace: creating {}", package_dir.to_str());
|
2013-06-30 22:51:13 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Created {} and does it exist? {:?}", package_dir.to_str(),
|
2013-06-14 20:16:24 -05:00
|
|
|
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 19:45:16 -05:00
|
|
|
"fn main() { let _x = (); }");
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("lib.rs"),
|
2013-05-27 19:45:16 -05:00
|
|
|
"pub fn f() { let _x = (); }");
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("test.rs"),
|
2013-05-27 19:45:16 -05:00
|
|
|
"#[test] pub fn f() { (); }");
|
2013-05-27 18:04:00 -05:00
|
|
|
writeFile(&package_dir.push("bench.rs"),
|
2013-05-27 19:45:16 -05:00
|
|
|
"#[bench] pub fn f() { (); }");
|
2013-10-11 08:55:37 -05:00
|
|
|
(workspace_dir, package_dir)
|
2013-04-24 19:37:59 -05:00
|
|
|
}
|
|
|
|
|
2013-07-31 15:47:32 -05:00
|
|
|
fn run_git(args: &[~str], env: Option<~[(~str, ~str)]>, cwd: &Path, err_msg: &str) {
|
|
|
|
let cwd = (*cwd).clone();
|
2013-08-29 16:20:48 -05:00
|
|
|
let mut prog = run::Process::new("git", args, run::ProcessOptions {
|
2013-08-13 17:56:17 -05:00
|
|
|
env: env,
|
2013-07-31 15:47:32 -05:00
|
|
|
dir: Some(&cwd),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
let rslt = prog.finish_with_output();
|
|
|
|
if rslt.status != 0 {
|
2013-09-28 01:37:25 -05:00
|
|
|
fail2!("{} [git returned {:?}, output = {}, error = {}]", err_msg,
|
2013-09-05 07:17:24 -05:00
|
|
|
rslt.status, str::from_utf8(rslt.output), str::from_utf8(rslt.error));
|
2013-07-31 15:47:32 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-09 20:28:00 -05:00
|
|
|
/// Should create an empty git repo in p, relative to the tmp dir, and return the new
|
|
|
|
/// absolute path
|
2013-10-11 08:55:37 -05:00
|
|
|
fn init_git_repo(p: &Path) -> TempDir {
|
2013-07-09 20:28:00 -05:00
|
|
|
assert!(!p.is_absolute());
|
2013-10-11 08:55:37 -05:00
|
|
|
let tmp = TempDir::new("git_local").expect("couldn't create temp dir");
|
|
|
|
let work_dir = tmp.path().push_rel(p);
|
2013-07-09 20:28:00 -05:00
|
|
|
let work_dir_for_opts = work_dir.clone();
|
|
|
|
assert!(os::mkdir_recursive(&work_dir, U_RWX));
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Running: git init in {}", work_dir.to_str());
|
2013-07-31 15:47:32 -05:00
|
|
|
let ws = work_dir.to_str();
|
|
|
|
run_git([~"init"], None, &work_dir_for_opts,
|
2013-09-28 01:37:25 -05:00
|
|
|
format!("Couldn't initialize git repository in {}", ws));
|
2013-07-31 15:47:32 -05:00
|
|
|
// Add stuff to the dir so that git tag succeeds
|
|
|
|
writeFile(&work_dir.push("README"), "");
|
2013-09-28 01:37:25 -05:00
|
|
|
run_git([~"add", ~"README"], None, &work_dir_for_opts, format!("Couldn't add in {}", ws));
|
2013-07-31 15:47:32 -05:00
|
|
|
git_commit(&work_dir_for_opts, ~"whatever");
|
|
|
|
tmp
|
2013-07-09 20:28:00 -05:00
|
|
|
}
|
|
|
|
|
2013-07-24 20:42:14 -05:00
|
|
|
fn add_all_and_commit(repo: &Path) {
|
|
|
|
git_add_all(repo);
|
|
|
|
git_commit(repo, ~"floop");
|
|
|
|
}
|
|
|
|
|
|
|
|
fn git_commit(repo: &Path, msg: ~str) {
|
2013-07-31 15:47:32 -05:00
|
|
|
run_git([~"commit", ~"--author=tester <test@mozilla.com>", ~"-m", msg],
|
2013-09-28 01:37:25 -05:00
|
|
|
None, repo, format!("Couldn't commit in {}", repo.to_str()));
|
2013-07-24 20:42:14 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn git_add_all(repo: &Path) {
|
2013-09-28 01:37:25 -05:00
|
|
|
run_git([~"add", ~"-A"], None, repo, format!("Couldn't add all files in {}", repo.to_str()));
|
2013-07-24 20:42:14 -05:00
|
|
|
}
|
2013-07-09 20:28:00 -05:00
|
|
|
|
2013-07-24 20:42:14 -05:00
|
|
|
fn add_git_tag(repo: &Path, tag: ~str) {
|
|
|
|
assert!(repo.is_absolute());
|
|
|
|
git_add_all(repo);
|
|
|
|
git_commit(repo, ~"whatever");
|
2013-07-31 15:47:32 -05:00
|
|
|
run_git([~"tag", tag.clone()], None, repo,
|
2013-09-28 01:37:25 -05:00
|
|
|
format!("Couldn't add git tag {} in {}", tag, repo.to_str()));
|
2013-07-09 20:28:00 -05:00
|
|
|
}
|
|
|
|
|
2013-04-24 19:37:59 -05:00
|
|
|
fn is_rwx(p: &Path) -> bool {
|
2013-06-28 17:32:26 -05:00
|
|
|
use std::libc::consts::os::posix88::{S_IRUSR, S_IWUSR, S_IXUSR};
|
2013-04-24 19:37:59 -05:00
|
|
|
|
|
|
|
match p.get_mode() {
|
|
|
|
None => return false,
|
2013-05-02 15:09:28 -05:00
|
|
|
Some(m) =>
|
2013-04-24 19:37:59 -05: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-10-05 15:40:01 -05:00
|
|
|
fn is_read_only(p: &Path) -> bool {
|
|
|
|
use std::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) == 0 as uint
|
|
|
|
&& (m & S_IXUSR as uint) == 0 as uint)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-03 18:47:53 -05:00
|
|
|
fn test_sysroot() -> Path {
|
|
|
|
// Totally gross hack but it's just for test cases.
|
2013-05-14 09:25:13 -05: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 18:47:53 -05:00
|
|
|
let self_path = os::self_exe_path().expect("Couldn't get self_exe path");
|
2013-05-14 09:25:13 -05:00
|
|
|
self_path.pop()
|
2013-05-03 18:47:53 -05:00
|
|
|
}
|
|
|
|
|
2013-07-31 15:47:32 -05:00
|
|
|
// Returns the path to rustpkg
|
|
|
|
fn rustpkg_exec() -> Path {
|
|
|
|
// Ugh
|
2013-09-12 20:48:02 -05:00
|
|
|
let first_try = test_sysroot().push_many(
|
|
|
|
[~"lib", ~"rustc", host_triple(), ~"bin", ~"rustpkg"]);
|
2013-07-31 15:47:32 -05:00
|
|
|
if is_executable(&first_try) {
|
|
|
|
first_try
|
|
|
|
}
|
|
|
|
else {
|
2013-09-12 20:48:02 -05:00
|
|
|
let second_try = test_sysroot().push_many([~"bin", ~"rustpkg"]);
|
2013-07-31 15:47:32 -05:00
|
|
|
if is_executable(&second_try) {
|
|
|
|
second_try
|
|
|
|
}
|
|
|
|
else {
|
2013-09-28 01:37:25 -05:00
|
|
|
fail2!("in rustpkg test, can't find an installed rustpkg");
|
2013-07-31 15:47:32 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-11 20:20:31 -05:00
|
|
|
fn command_line_test(args: &[~str], cwd: &Path) -> ProcessOutput {
|
2013-09-16 21:27:09 -05:00
|
|
|
match command_line_test_with_env(args, cwd, None) {
|
|
|
|
Success(r) => r,
|
2013-09-28 01:37:25 -05:00
|
|
|
_ => fail2!("Command line test failed")
|
2013-09-16 21:27:09 -05:00
|
|
|
}
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
2013-09-16 21:27:09 -05:00
|
|
|
fn command_line_test_partial(args: &[~str], cwd: &Path) -> ProcessResult {
|
2013-07-11 20:20:31 -05:00
|
|
|
command_line_test_with_env(args, cwd, None)
|
|
|
|
}
|
|
|
|
|
2013-09-16 21:27:09 -05:00
|
|
|
enum ProcessResult {
|
|
|
|
Success(ProcessOutput),
|
|
|
|
Fail(int) // exit code
|
|
|
|
}
|
|
|
|
|
2013-06-14 20:16:24 -05: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 20:20:31 -05:00
|
|
|
fn command_line_test_with_env(args: &[~str], cwd: &Path, env: Option<~[(~str, ~str)]>)
|
2013-09-16 21:27:09 -05:00
|
|
|
-> ProcessResult {
|
2013-07-31 15:47:32 -05:00
|
|
|
let cmd = rustpkg_exec().to_str();
|
2013-09-12 20:48:02 -05:00
|
|
|
let env_str = match env {
|
2013-09-28 01:37:25 -05:00
|
|
|
Some(ref pairs) => pairs.map(|&(ref k, ref v)| { format!("{}={}", *k, *v) }).connect(","),
|
2013-09-12 20:48:02 -05:00
|
|
|
None => ~""
|
|
|
|
};
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("{} cd {}; {} {}", env_str, cwd.to_str(), cmd, args.connect(" "));
|
2013-06-14 20:16:24 -05:00
|
|
|
assert!(os::path_is_dir(&*cwd));
|
2013-07-17 01:49:42 -05:00
|
|
|
let cwd = (*cwd).clone();
|
2013-07-11 20:20:31 -05:00
|
|
|
let mut prog = run::Process::new(cmd, args, run::ProcessOptions {
|
2013-08-15 20:36:39 -05:00
|
|
|
env: env.map(|e| e + os::env()),
|
2013-07-11 20:20:31 -05:00
|
|
|
dir: Some(&cwd),
|
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
2013-08-29 16:20:48 -05:00
|
|
|
});
|
2013-06-14 20:16:24 -05:00
|
|
|
let output = prog.finish_with_output();
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Output from command {} with args {:?} was {} \\{{}\\}[{:?}]",
|
2013-09-05 07:17:24 -05:00
|
|
|
cmd, args, str::from_utf8(output.output),
|
|
|
|
str::from_utf8(output.error),
|
2013-06-27 18:27:13 -05:00
|
|
|
output.status);
|
2013-06-14 20:16:24 -05: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 {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Command {} {:?} failed with exit code {:?}; its output was --- {} ---",
|
2013-07-31 15:47:32 -05:00
|
|
|
cmd, args, output.status,
|
2013-09-05 07:17:24 -05:00
|
|
|
str::from_utf8(output.output) + str::from_utf8(output.error));
|
2013-09-16 21:27:09 -05:00
|
|
|
Fail(output.status)
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
else {
|
2013-09-16 21:27:09 -05:00
|
|
|
Success(output)
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
fn create_local_package(pkgid: &PkgId) -> TempDir {
|
|
|
|
let (workspace, parent_dir) = mk_temp_workspace(&pkgid.path, &pkgid.version);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Created empty package dir for {}, returning {}", pkgid.to_str(), parent_dir.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package_in(pkgid: &PkgId, pkgdir: &Path) -> Path {
|
|
|
|
|
2013-09-12 20:48:02 -05:00
|
|
|
let package_dir = pkgdir.push_many([~"src", pkgid.to_str()]);
|
2013-06-14 20:16:24 -05:00
|
|
|
|
|
|
|
// Create main, lib, test, and bench files
|
2013-06-30 22:51:13 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Created {} and does it exist? {:?}", package_dir.to_str(),
|
2013-06-14 20:16:24 -05:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
fn create_local_package_with_test(pkgid: &PkgId) -> TempDir {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Dry run -- would create package {:?} with test", pkgid);
|
2013-06-14 20:16:24 -05:00
|
|
|
create_local_package(pkgid) // Already has tests???
|
|
|
|
}
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
fn create_local_package_with_dep(pkgid: &PkgId, subord_pkgid: &PkgId) -> TempDir {
|
2013-06-14 20:16:24 -05:00
|
|
|
let package_dir = create_local_package(pkgid);
|
2013-10-11 08:55:37 -05:00
|
|
|
create_local_package_in(subord_pkgid, package_dir.path());
|
2013-06-14 20:16:24 -05:00
|
|
|
// Write a main.rs file into pkgid that references subord_pkgid
|
2013-10-11 08:55:37 -05:00
|
|
|
writeFile(&package_dir.path().push_many([~"src", pkgid.to_str(), ~"main.rs"]),
|
2013-09-28 01:37:25 -05:00
|
|
|
format!("extern mod {};\nfn main() \\{\\}",
|
2013-06-14 20:16:24 -05:00
|
|
|
subord_pkgid.short_name));
|
|
|
|
// Write a lib.rs file into subord_pkgid that has something in it
|
2013-10-11 08:55:37 -05:00
|
|
|
writeFile(&package_dir.path().push_many([~"src", subord_pkgid.to_str(), ~"lib.rs"]),
|
2013-06-14 20:16:24 -05:00
|
|
|
"pub fn f() {}");
|
|
|
|
package_dir
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_local_package_with_custom_build_hook(pkgid: &PkgId,
|
2013-10-11 08:55:37 -05:00
|
|
|
custom_build_hook: &str) -> TempDir {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Dry run -- would create package {} with custom build hook {}",
|
2013-06-14 20:16:24 -05:00
|
|
|
pkgid.to_str(), custom_build_hook);
|
|
|
|
create_local_package(pkgid)
|
|
|
|
// actually write the pkg.rs with the custom build hook
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-09-12 15:56:11 -05:00
|
|
|
fn assert_lib_exists(repo: &Path, pkg_path: &Path, v: Version) {
|
|
|
|
assert!(lib_exists(repo, pkg_path, v));
|
2013-08-28 16:52:37 -05:00
|
|
|
}
|
|
|
|
|
2013-09-12 15:56:11 -05:00
|
|
|
fn lib_exists(repo: &Path, pkg_path: &Path, _v: Version) -> bool { // ??? version?
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("assert_lib_exists: repo = {}, pkg_path = {}", repo.to_str(), pkg_path.to_str());
|
2013-09-12 15:56:11 -05:00
|
|
|
let lib = installed_library_in_workspace(pkg_path, repo);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("assert_lib_exists: checking whether {:?} exists", lib);
|
2013-08-28 16:52:37 -05:00
|
|
|
lib.is_some() && {
|
|
|
|
let libname = lib.get_ref();
|
|
|
|
os::path_exists(libname) && is_rwx(libname)
|
|
|
|
}
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn assert_executable_exists(repo: &Path, short_name: &str) {
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(executable_exists(repo, short_name));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn executable_exists(repo: &Path, short_name: &str) -> bool {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("executable_exists: repo = {}, short_name = {}", repo.to_str(), short_name);
|
2013-07-31 15:47:32 -05:00
|
|
|
let exec = target_executable_in_workspace(&PkgId::new(short_name), repo);
|
2013-08-28 16:52:37 -05:00
|
|
|
os::path_exists(&exec) && is_rwx(&exec)
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
2013-09-26 18:04:49 -05:00
|
|
|
fn test_executable_exists(repo: &Path, short_name: &str) -> bool {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("test_executable_exists: repo = {}, short_name = {}", repo.to_str(), short_name);
|
2013-09-26 18:04:49 -05:00
|
|
|
let exec = built_test_in_workspace(&PkgId::new(short_name), repo);
|
|
|
|
do exec.map_default(false) |exec| {
|
2013-09-20 01:08:47 -05:00
|
|
|
os::path_exists(&exec) && is_rwx(&exec)
|
2013-09-26 18:04:49 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-17 20:23:34 -05:00
|
|
|
fn remove_executable_file(p: &PkgId, workspace: &Path) {
|
|
|
|
let exec = target_executable_in_workspace(&PkgId::new(p.short_name), workspace);
|
|
|
|
if os::path_exists(&exec) {
|
|
|
|
assert!(os::remove_file(&exec));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-26 19:42:24 -05:00
|
|
|
fn assert_built_executable_exists(repo: &Path, short_name: &str) {
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(built_executable_exists(repo, short_name));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn built_executable_exists(repo: &Path, short_name: &str) -> bool {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("assert_built_executable_exists: repo = {}, short_name = {}",
|
|
|
|
repo.to_str(), short_name);
|
2013-08-28 16:52:37 -05:00
|
|
|
let exec = built_executable_in_workspace(&PkgId::new(short_name), repo);
|
|
|
|
exec.is_some() && {
|
|
|
|
let execname = exec.get_ref();
|
|
|
|
os::path_exists(execname) && is_rwx(execname)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-17 20:23:34 -05:00
|
|
|
fn remove_built_executable_file(p: &PkgId, workspace: &Path) {
|
|
|
|
let exec = built_executable_in_workspace(&PkgId::new(p.short_name), workspace);
|
|
|
|
match exec {
|
|
|
|
Some(r) => assert!(os::remove_file(&r)),
|
|
|
|
None => ()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-10 13:41:05 -05:00
|
|
|
fn object_file_exists(repo: &Path, short_name: &str) -> bool {
|
|
|
|
file_exists(repo, short_name, "o")
|
|
|
|
}
|
|
|
|
|
|
|
|
fn assembly_file_exists(repo: &Path, short_name: &str) -> bool {
|
|
|
|
file_exists(repo, short_name, "s")
|
|
|
|
}
|
|
|
|
|
|
|
|
fn llvm_assembly_file_exists(repo: &Path, short_name: &str) -> bool {
|
|
|
|
file_exists(repo, short_name, "ll")
|
|
|
|
}
|
|
|
|
|
|
|
|
fn llvm_bitcode_file_exists(repo: &Path, short_name: &str) -> bool {
|
|
|
|
file_exists(repo, short_name, "bc")
|
|
|
|
}
|
|
|
|
|
|
|
|
fn file_exists(repo: &Path, short_name: &str, extension: &str) -> bool {
|
2013-09-12 21:29:21 -05:00
|
|
|
os::path_exists(&target_build_dir(repo).push_many([short_name.to_owned(),
|
2013-09-28 01:37:25 -05:00
|
|
|
format!("{}.{}", short_name, extension)]))
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
2013-08-28 16:52:37 -05:00
|
|
|
fn assert_built_library_exists(repo: &Path, short_name: &str) {
|
|
|
|
assert!(built_library_exists(repo, short_name));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn built_library_exists(repo: &Path, short_name: &str) -> bool {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("assert_built_library_exists: repo = {}, short_name = {}", repo.to_str(), short_name);
|
2013-08-28 16:52:37 -05:00
|
|
|
let lib = built_library_in_workspace(&PkgId::new(short_name), repo);
|
|
|
|
lib.is_some() && {
|
|
|
|
let libname = lib.get_ref();
|
|
|
|
os::path_exists(libname) && is_rwx(libname)
|
|
|
|
}
|
2013-06-26 19:42:24 -05:00
|
|
|
}
|
|
|
|
|
2013-06-14 20:16:24 -05:00
|
|
|
fn command_line_test_output(args: &[~str]) -> ~[~str] {
|
|
|
|
let mut result = ~[];
|
|
|
|
let p_output = command_line_test(args, &os::getcwd());
|
2013-09-05 07:17:24 -05:00
|
|
|
let test_output = str::from_utf8(p_output.output);
|
2013-08-03 11:45:23 -05:00
|
|
|
for s in test_output.split_iter('\n') {
|
2013-06-25 20:25:27 -05:00
|
|
|
result.push(s.to_owned());
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
result
|
|
|
|
}
|
|
|
|
|
2013-07-11 20:20:31 -05:00
|
|
|
fn command_line_test_output_with_env(args: &[~str], env: ~[(~str, ~str)]) -> ~[~str] {
|
|
|
|
let mut result = ~[];
|
2013-09-16 21:27:09 -05:00
|
|
|
let p_output = match command_line_test_with_env(args,
|
|
|
|
&os::getcwd(), Some(env)) {
|
2013-09-28 01:37:25 -05:00
|
|
|
Fail(_) => fail2!("Command-line test failed"),
|
2013-09-16 21:27:09 -05:00
|
|
|
Success(r) => r
|
|
|
|
};
|
2013-09-05 07:17:24 -05:00
|
|
|
let test_output = str::from_utf8(p_output.output);
|
2013-08-03 11:45:23 -05:00
|
|
|
for s in test_output.split_iter('\n') {
|
2013-07-11 20:20:31 -05:00
|
|
|
result.push(s.to_owned());
|
|
|
|
}
|
|
|
|
result
|
|
|
|
}
|
|
|
|
|
2013-08-02 18:59:58 -05:00
|
|
|
// assumes short_name and path are one and the same -- I should fix
|
2013-09-16 21:27:09 -05:00
|
|
|
fn lib_output_file_name(workspace: &Path, short_name: &str) -> Path {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("lib_output_file_name: given {} and short name {}",
|
2013-09-16 21:27:09 -05:00
|
|
|
workspace.to_str(), short_name);
|
2013-08-02 18:59:58 -05:00
|
|
|
library_in_workspace(&Path(short_name),
|
2013-06-14 20:16:24 -05:00
|
|
|
short_name,
|
|
|
|
Build,
|
|
|
|
workspace,
|
2013-08-15 20:36:39 -05:00
|
|
|
"build",
|
|
|
|
&NoVersion).expect("lib_output_file_name")
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
2013-09-12 20:48:02 -05:00
|
|
|
fn output_file_name(workspace: &Path, short_name: ~str) -> Path {
|
2013-09-28 01:37:25 -05:00
|
|
|
target_build_dir(workspace).push(short_name).push(format!("{}{}", short_name, os::EXE_SUFFIX))
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
2013-06-21 14:38:10 -05:00
|
|
|
fn touch_source_file(workspace: &Path, pkgid: &PkgId) {
|
2013-06-14 20:16:24 -05:00
|
|
|
use conditions::bad_path::cond;
|
2013-09-12 20:48:02 -05:00
|
|
|
let pkg_src_dir = workspace.push_many([~"src", pkgid.to_str()]);
|
2013-06-21 14:38:10 -05:00
|
|
|
let contents = os::list_dir_path(&pkg_src_dir);
|
2013-08-03 11:45:23 -05:00
|
|
|
for p in contents.iter() {
|
2013-09-04 06:10:22 -05:00
|
|
|
if p.filetype() == Some(".rs") {
|
2013-06-14 20:16:24 -05:00
|
|
|
// should be able to do this w/o a process
|
|
|
|
if run::process_output("touch", [p.to_str()]).status != 0 {
|
2013-07-02 14:47:32 -05:00
|
|
|
let _ = cond.raise((pkg_src_dir.clone(), ~"Bad path"));
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-06 22:29:16 -05:00
|
|
|
/// Add a comment at the end
|
2013-09-16 21:27:09 -05:00
|
|
|
fn frob_source_file(workspace: &Path, pkgid: &PkgId, filename: &str) {
|
2013-06-14 20:16:24 -05:00
|
|
|
use conditions::bad_path::cond;
|
2013-09-12 20:48:02 -05:00
|
|
|
let pkg_src_dir = workspace.push_many([~"src", pkgid.to_str()]);
|
2013-06-14 20:16:24 -05:00
|
|
|
let mut maybe_p = None;
|
2013-09-16 21:27:09 -05:00
|
|
|
let maybe_file = pkg_src_dir.push(filename);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Trying to frob {} -- {}", pkg_src_dir.to_str(), filename);
|
2013-09-16 21:27:09 -05:00
|
|
|
if os::path_exists(&maybe_file) {
|
|
|
|
maybe_p = Some(maybe_file);
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Frobbed? {:?}", maybe_p);
|
2013-06-14 20:16:24 -05:00
|
|
|
match maybe_p {
|
2013-09-16 21:27:09 -05:00
|
|
|
Some(ref p) => {
|
2013-07-21 12:33:29 -05:00
|
|
|
let w = io::file_writer(p, &[io::Append]);
|
2013-06-14 20:16:24 -05:00
|
|
|
match w {
|
2013-09-28 01:37:25 -05:00
|
|
|
Err(s) => { let _ = cond.raise((p.clone(), format!("Bad path: {}", s))); }
|
2013-09-06 22:29:16 -05:00
|
|
|
Ok(w) => w.write_line("/* hi */")
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
}
|
2013-10-05 15:40:01 -05:00
|
|
|
None => fail2!("frob_source_file failed to find a source file in {}",
|
|
|
|
pkg_src_dir.to_str())
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-15 20:36:39 -05:00
|
|
|
#[test]
|
2013-04-24 19:37:59 -05: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 15:09:28 -05:00
|
|
|
assert!(!os::path_exists(&dir) ||
|
|
|
|
os::remove_dir_recursive(&dir));
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Trying to make {}", dir.to_str());
|
2013-04-24 19:37:59 -05:00
|
|
|
assert!(make_dir_rwx(&dir));
|
|
|
|
assert!(os::path_is_dir(&dir));
|
|
|
|
assert!(is_rwx(&dir));
|
2013-05-02 15:09:28 -05:00
|
|
|
assert!(os::remove_dir_recursive(&dir));
|
2013-04-24 19:37:59 -05:00
|
|
|
}
|
|
|
|
|
2013-08-15 20:36:39 -05:00
|
|
|
#[test]
|
2013-04-24 19:37:59 -05:00
|
|
|
fn test_install_valid() {
|
2013-05-27 19:45:16 -05:00
|
|
|
use path_util::installed_library_in_workspace;
|
|
|
|
|
2013-05-03 18:47:53 -05:00
|
|
|
let sysroot = test_sysroot();
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("sysroot = {}", sysroot.to_str());
|
2013-04-24 19:37:59 -05:00
|
|
|
let temp_pkg_id = fake_pkg();
|
2013-10-11 08:55:37 -05:00
|
|
|
let (temp_workspace, _pkg_dir) = mk_temp_workspace(&temp_pkg_id.path, &NoVersion);
|
|
|
|
let temp_workspace = temp_workspace.path();
|
|
|
|
let ctxt = fake_ctxt(sysroot, temp_workspace);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("temp_workspace = {}", temp_workspace.to_str());
|
2013-04-24 19:37:59 -05:00
|
|
|
// should have test, bench, lib, and main
|
2013-10-05 15:40:01 -05:00
|
|
|
let src = PkgSrc::new(temp_workspace.clone(),
|
|
|
|
temp_workspace.clone(),
|
|
|
|
false,
|
|
|
|
temp_pkg_id.clone());
|
2013-09-16 21:27:09 -05:00
|
|
|
ctxt.install(src, &Everything);
|
2013-04-24 19:37:59 -05:00
|
|
|
// Check that all files exist
|
2013-10-11 08:55:37 -05:00
|
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, temp_workspace);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("exec = {}", exec.to_str());
|
2013-04-24 19:37:59 -05:00
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
2013-05-27 19:45:16 -05:00
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
let lib = installed_library_in_workspace(&temp_pkg_id.path, temp_workspace);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("lib = {:?}", lib);
|
2013-09-20 01:08:47 -05:00
|
|
|
assert!(lib.as_ref().map_default(false, |l| os::path_exists(l)));
|
|
|
|
assert!(lib.as_ref().map_default(false, |l| is_rwx(l)));
|
2013-05-27 19:45:16 -05:00
|
|
|
|
2013-04-24 19:37:59 -05:00
|
|
|
// And that the test and bench executables aren't installed
|
2013-10-11 08:55:37 -05: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-09-28 01:37:25 -05:00
|
|
|
debug2!("bench = {}", bench.to_str());
|
2013-05-02 15:09:28 -05:00
|
|
|
assert!(!os::path_exists(&bench));
|
2013-10-11 08:55:37 -05:00
|
|
|
|
|
|
|
// Make sure the db isn't dirty, so that it doesn't try to save()
|
|
|
|
// asynchronously after the temporary directory that it wants to save
|
|
|
|
// to has been deleted.
|
|
|
|
ctxt.workcache_context.db.write(|db| db.db_dirty = false);
|
2013-04-24 19:37:59 -05:00
|
|
|
}
|
|
|
|
|
2013-08-15 20:36:39 -05:00
|
|
|
#[test]
|
2013-04-24 19:37:59 -05:00
|
|
|
fn test_install_invalid() {
|
2013-09-06 22:29:16 -05:00
|
|
|
let sysroot = test_sysroot();
|
2013-04-24 19:37:59 -05:00
|
|
|
let pkgid = fake_pkg();
|
2013-10-11 08:55:37 -05:00
|
|
|
let temp_workspace = TempDir::new("test").expect("couldn't create temp dir");
|
|
|
|
let temp_workspace = temp_workspace.path().clone();
|
2013-09-06 22:29:16 -05:00
|
|
|
let ctxt = fake_ctxt(sysroot, &temp_workspace);
|
|
|
|
|
|
|
|
// Uses task::try because of #9001
|
|
|
|
let result = do task::try {
|
2013-10-05 15:40:01 -05:00
|
|
|
let pkg_src = PkgSrc::new(temp_workspace.clone(),
|
|
|
|
temp_workspace.clone(),
|
|
|
|
false,
|
|
|
|
pkgid.clone());
|
2013-09-16 21:27:09 -05:00
|
|
|
ctxt.install(pkg_src, &Everything);
|
2013-09-06 22:29:16 -05:00
|
|
|
};
|
|
|
|
// Not the best test -- doesn't test that we failed in the right way.
|
|
|
|
// Best we can do for now.
|
|
|
|
assert!(result == Err(()));
|
2013-04-26 11:24:15 -05:00
|
|
|
}
|
2013-05-03 18:47:53 -05:00
|
|
|
|
2013-07-09 20:28:00 -05:00
|
|
|
// Tests above should (maybe) be converted to shell out to rustpkg, too
|
2013-08-21 17:46:27 -05:00
|
|
|
#[test]
|
2013-07-09 20:28:00 -05:00
|
|
|
fn test_install_git() {
|
|
|
|
let temp_pkg_id = git_repo_pkg();
|
2013-08-02 18:59:58 -05:00
|
|
|
let repo = init_git_repo(&temp_pkg_id.path);
|
2013-10-11 08:55:37 -05:00
|
|
|
let repo = repo.path();
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("repo = {}", repo.to_str());
|
2013-09-12 20:48:02 -05:00
|
|
|
let repo_subdir = repo.push_many([~"mockgithub.com", ~"catamorphism", ~"test-pkg"]);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("repo_subdir = {}", repo_subdir.to_str());
|
2013-08-21 17:46:27 -05:00
|
|
|
|
2013-07-09 20:28:00 -05:00
|
|
|
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
|
|
|
|
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("test_install_git: calling rustpkg install {} in {}",
|
2013-08-02 18:59:58 -05:00
|
|
|
temp_pkg_id.path.to_str(), repo.to_str());
|
2013-05-03 18:47:53 -05:00
|
|
|
// should have test, bench, lib, and main
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", temp_pkg_id.path.to_str()], repo);
|
2013-08-21 17:46:27 -05:00
|
|
|
let ws = repo.push(".rust");
|
2013-05-03 18:47:53 -05:00
|
|
|
// Check that all files exist
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Checking for files in {}", ws.to_str());
|
2013-08-21 17:46:27 -05:00
|
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, &ws);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("exec = {}", exec.to_str());
|
2013-05-03 18:47:53 -05:00
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
2013-06-14 20:16:24 -05:00
|
|
|
let _built_lib =
|
2013-06-01 17:59:12 -05:00
|
|
|
built_library_in_workspace(&temp_pkg_id,
|
2013-08-21 17:46:27 -05:00
|
|
|
&ws).expect("test_install_git: built lib should exist");
|
2013-09-12 15:56:11 -05:00
|
|
|
assert_lib_exists(&ws, &temp_pkg_id.path, temp_pkg_id.version.clone());
|
2013-05-27 19:45:16 -05:00
|
|
|
let built_test = built_test_in_workspace(&temp_pkg_id,
|
2013-08-21 17:46:27 -05:00
|
|
|
&ws).expect("test_install_git: built test should exist");
|
2013-05-10 21:00:51 -05:00
|
|
|
assert!(os::path_exists(&built_test));
|
2013-05-14 19:46:52 -05:00
|
|
|
let built_bench = built_bench_in_workspace(&temp_pkg_id,
|
2013-08-21 17:46:27 -05:00
|
|
|
&ws).expect("test_install_git: built bench should exist");
|
2013-05-10 21:00:51 -05:00
|
|
|
assert!(os::path_exists(&built_bench));
|
2013-05-03 18:47:53 -05:00
|
|
|
// And that the test and bench executables aren't installed
|
2013-08-21 17:46:27 -05:00
|
|
|
let test = target_test_in_workspace(&temp_pkg_id, &ws);
|
2013-05-10 21:00:51 -05:00
|
|
|
assert!(!os::path_exists(&test));
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("test = {}", test.to_str());
|
2013-08-21 17:46:27 -05:00
|
|
|
let bench = target_bench_in_workspace(&temp_pkg_id, &ws);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("bench = {}", bench.to_str());
|
2013-05-03 18:47:53 -05:00
|
|
|
assert!(!os::path_exists(&bench));
|
2013-05-12 15:50:57 -05:00
|
|
|
}
|
2013-05-14 19:46:52 -05:00
|
|
|
|
2013-08-15 20:36:39 -05:00
|
|
|
#[test]
|
2013-05-14 19:46:52 -05: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-31 15:47:32 -05:00
|
|
|
let whatever = PkgId::new("foo");
|
2013-05-14 19:46:52 -05:00
|
|
|
|
2013-06-14 20:16:24 -05:00
|
|
|
assert_eq!(~"foo-0.1", whatever.to_str());
|
2013-08-02 18:59:58 -05:00
|
|
|
assert!("github.com/catamorphism/test-pkg-0.1" ==
|
2013-07-31 15:47:32 -05:00
|
|
|
PkgId::new("github.com/catamorphism/test-pkg").to_str());
|
2013-05-14 19:46:52 -05:00
|
|
|
|
|
|
|
do cond.trap(|(p, e)| {
|
|
|
|
assert!("" == p.to_str());
|
|
|
|
assert!("0-length pkgid" == e);
|
2013-07-02 14:47:32 -05:00
|
|
|
whatever.clone()
|
2013-07-31 16:59:59 -05:00
|
|
|
}).inside {
|
2013-07-31 15:47:32 -05:00
|
|
|
let x = PkgId::new("");
|
2013-06-14 20:16:24 -05:00
|
|
|
assert_eq!(~"foo-0.1", x.to_str());
|
2013-05-14 19:46:52 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
do cond.trap(|(p, e)| {
|
2013-05-18 21:02:45 -05:00
|
|
|
assert_eq!(p.to_str(), os::make_absolute(&Path("foo/bar/quux")).to_str());
|
2013-05-14 19:46:52 -05:00
|
|
|
assert!("absolute pkgid" == e);
|
2013-07-02 14:47:32 -05:00
|
|
|
whatever.clone()
|
2013-07-31 16:59:59 -05:00
|
|
|
}).inside {
|
2013-07-31 15:47:32 -05:00
|
|
|
let z = PkgId::new(os::make_absolute(&Path("foo/bar/quux")).to_str());
|
2013-06-14 20:16:24 -05:00
|
|
|
assert_eq!(~"foo-0.1", z.to_str());
|
2013-05-14 19:46:52 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2013-05-30 14:03:21 -05:00
|
|
|
|
2013-08-21 17:46:27 -05:00
|
|
|
#[test]
|
2013-05-30 14:03:21 -05:00
|
|
|
fn test_package_version() {
|
2013-07-09 20:28:00 -05:00
|
|
|
let local_path = "mockgithub.com/catamorphism/test_pkg_version";
|
|
|
|
let repo = init_git_repo(&Path(local_path));
|
2013-10-11 08:55:37 -05:00
|
|
|
let repo = repo.path();
|
2013-09-12 20:48:02 -05:00
|
|
|
let repo_subdir = repo.push_many([~"mockgithub.com", ~"catamorphism", ~"test_pkg_version"]);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Writing files in: {}", repo_subdir.to_str());
|
2013-07-09 20:28:00 -05:00
|
|
|
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");
|
|
|
|
|
2013-08-21 17:46:27 -05:00
|
|
|
// It won't pick up the 0.4 version because the dir isn't in the RUST_PATH, but...
|
2013-07-31 15:47:32 -05:00
|
|
|
let temp_pkg_id = PkgId::new("mockgithub.com/catamorphism/test_pkg_version");
|
2013-07-09 20:28:00 -05:00
|
|
|
// This should look at the prefix, clone into a workspace, then build.
|
|
|
|
command_line_test([~"install", ~"mockgithub.com/catamorphism/test_pkg_version"],
|
2013-10-11 08:55:37 -05:00
|
|
|
repo);
|
2013-08-21 17:46:27 -05:00
|
|
|
let ws = repo.push(".rust");
|
|
|
|
// we can still match on the filename to make sure it contains the 0.4 version
|
2013-07-09 20:28:00 -05:00
|
|
|
assert!(match built_library_in_workspace(&temp_pkg_id,
|
2013-08-21 17:46:27 -05:00
|
|
|
&ws) {
|
2013-09-28 01:37:25 -05:00
|
|
|
Some(p) => p.to_str().ends_with(format!("0.4{}", os::consts::DLL_SUFFIX)),
|
2013-06-01 17:59:12 -05:00
|
|
|
None => false
|
|
|
|
});
|
2013-08-21 17:46:27 -05:00
|
|
|
assert!(built_executable_in_workspace(&temp_pkg_id, &ws)
|
2013-09-12 21:29:21 -05:00
|
|
|
== Some(target_build_dir(&ws).push_many([~"mockgithub.com",
|
|
|
|
~"catamorphism",
|
|
|
|
~"test_pkg_version",
|
|
|
|
~"test_pkg_version"])));
|
2013-06-01 17:59:12 -05:00
|
|
|
}
|
|
|
|
|
2013-08-21 17:46:27 -05:00
|
|
|
#[test]
|
2013-06-01 17:59:12 -05:00
|
|
|
fn test_package_request_version() {
|
2013-07-09 20:28:00 -05:00
|
|
|
let local_path = "mockgithub.com/catamorphism/test_pkg_version";
|
|
|
|
let repo = init_git_repo(&Path(local_path));
|
2013-10-11 08:55:37 -05:00
|
|
|
let repo = repo.path();
|
2013-09-12 20:48:02 -05:00
|
|
|
let repo_subdir = repo.push_many([~"mockgithub.com", ~"catamorphism", ~"test_pkg_version"]);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Writing files in: {}", repo_subdir.to_str());
|
2013-07-09 20:28:00 -05:00
|
|
|
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");
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", format!("{}\\#0.3", local_path)], repo);
|
2013-07-09 20:28:00 -05:00
|
|
|
|
2013-09-12 15:56:11 -05:00
|
|
|
assert!(match installed_library_in_workspace(&Path("test_pkg_version"), &repo.push(".rust")) {
|
2013-06-01 17:59:12 -05:00
|
|
|
Some(p) => {
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("installed: {}", p.to_str());
|
|
|
|
p.to_str().ends_with(format!("0.3{}", os::consts::DLL_SUFFIX))
|
2013-06-01 17:59:12 -05:00
|
|
|
}
|
|
|
|
None => false
|
|
|
|
});
|
2013-07-31 15:47:32 -05:00
|
|
|
let temp_pkg_id = PkgId::new("mockgithub.com/catamorphism/test_pkg_version#0.3");
|
2013-07-09 20:28:00 -05:00
|
|
|
assert!(target_executable_in_workspace(&temp_pkg_id, &repo.push(".rust"))
|
2013-09-12 20:48:02 -05:00
|
|
|
== repo.push_many([~".rust", ~"bin", ~"test_pkg_version"]));
|
|
|
|
|
2013-10-05 15:40:01 -05:00
|
|
|
let dir = target_build_dir(&repo.push(".rust"))
|
|
|
|
.push_rel(&Path("src/mockgithub.com/catamorphism/test_pkg_version-0.3"));
|
|
|
|
debug2!("dir = {}", dir.to_str());
|
|
|
|
assert!(os::path_is_dir(&dir));
|
2013-09-12 20:48:02 -05:00
|
|
|
assert!(os::path_exists(&dir.push("version-0.3-file.txt")));
|
|
|
|
assert!(!os::path_exists(&dir.push("version-0.4-file.txt")));
|
2013-05-30 14:03:21 -05:00
|
|
|
}
|
2013-06-14 20:16:24 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore (reason = "http-client not ported to rustpkg yet")]
|
|
|
|
fn rustpkg_install_url_2() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let temp_dir = TempDir::new("rustpkg_install_url_2").expect("rustpkg_install_url_2");
|
2013-06-14 20:16:24 -05:00
|
|
|
command_line_test([~"install", ~"github.com/mozilla-servo/rust-http-client"],
|
2013-10-11 08:55:37 -05:00
|
|
|
temp_dir.path());
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
2013-07-24 20:42:14 -05:00
|
|
|
#[test]
|
2013-06-14 20:16:24 -05:00
|
|
|
fn rustpkg_library_target() {
|
2013-07-09 20:28:00 -05:00
|
|
|
let foo_repo = init_git_repo(&Path("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
let foo_repo = foo_repo.path();
|
2013-07-09 20:28:00 -05:00
|
|
|
let package_dir = foo_repo.push("foo");
|
|
|
|
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Writing files in: {}", package_dir.to_str());
|
2013-07-09 20:28:00 -05:00
|
|
|
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-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], foo_repo);
|
2013-09-12 15:56:11 -05:00
|
|
|
assert_lib_exists(&foo_repo.push(".rust"), &Path("foo"), ExactRevision(~"1.0"));
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rustpkg_local_pkg() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let dir = create_local_package(&PkgId::new("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], dir.path());
|
|
|
|
assert_executable_exists(dir.path(), "foo");
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
2013-06-26 00:26:22 -05:00
|
|
|
#[test]
|
2013-08-22 17:27:25 -05:00
|
|
|
#[ignore (reason = "test makes bogus assumptions about build directory layout: issue #8690")]
|
2013-06-26 00:26:22 -05:00
|
|
|
fn package_script_with_default_build() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let dir = create_local_package(&PkgId::new("fancy-lib"));
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = dir.path();
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("dir = {}", dir.to_str());
|
2013-09-12 20:48:02 -05:00
|
|
|
let source = test_sysroot().pop().pop().pop().push_many(
|
|
|
|
[~"src", ~"librustpkg", ~"testsuite", ~"pass", ~"src", ~"fancy-lib", ~"pkg.rs"]);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("package_script_with_default_build: {}", source.to_str());
|
2013-06-26 00:26:22 -05:00
|
|
|
if !os::copy_file(&source,
|
2013-09-12 20:48:02 -05:00
|
|
|
&dir.push_many([~"src", ~"fancy-lib-0.1", ~"pkg.rs"])) {
|
2013-09-28 01:37:25 -05:00
|
|
|
fail2!("Couldn't copy file");
|
2013-06-26 00:26:22 -05:00
|
|
|
}
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"fancy-lib"], dir);
|
|
|
|
assert_lib_exists(dir, &Path("fancy-lib"), NoVersion);
|
|
|
|
assert!(os::path_exists(&target_build_dir(dir).push_many([~"fancy-lib", ~"generated.rs"])));
|
2013-06-26 00:26:22 -05:00
|
|
|
}
|
|
|
|
|
2013-06-26 19:42:24 -05:00
|
|
|
#[test]
|
|
|
|
fn rustpkg_build_no_arg() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let tmp = TempDir::new("rustpkg_build_no_arg").expect("rustpkg_build_no_arg failed");
|
|
|
|
let tmp = tmp.path().push(".rust");
|
2013-09-12 20:48:02 -05:00
|
|
|
let package_dir = tmp.push_many([~"src", ~"foo"]);
|
2013-06-26 19:42:24 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
|
|
|
|
writeFile(&package_dir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("build_no_arg: dir = {}", package_dir.to_str());
|
2013-06-26 19:42:24 -05:00
|
|
|
command_line_test([~"build"], &package_dir);
|
|
|
|
assert_built_executable_exists(&tmp, "foo");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rustpkg_install_no_arg() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let tmp = TempDir::new("rustpkg_install_no_arg").expect("rustpkg_install_no_arg failed");
|
|
|
|
let tmp = tmp.path().push(".rust");
|
2013-09-12 20:48:02 -05:00
|
|
|
let package_dir = tmp.push_many([~"src", ~"foo"]);
|
2013-06-26 19:42:24 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
writeFile(&package_dir.push("lib.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("install_no_arg: dir = {}", package_dir.to_str());
|
2013-06-26 19:42:24 -05:00
|
|
|
command_line_test([~"install"], &package_dir);
|
2013-09-12 15:56:11 -05:00
|
|
|
assert_lib_exists(&tmp, &Path("foo"), NoVersion);
|
2013-06-26 19:42:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rustpkg_clean_no_arg() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let tmp = TempDir::new("rustpkg_clean_no_arg").expect("rustpkg_clean_no_arg failed");
|
|
|
|
let tmp = tmp.path().push(".rust");
|
2013-09-12 20:48:02 -05:00
|
|
|
let package_dir = tmp.push_many([~"src", ~"foo"]);
|
2013-06-26 19:42:24 -05:00
|
|
|
assert!(os::mkdir_recursive(&package_dir, U_RWX));
|
|
|
|
|
|
|
|
writeFile(&package_dir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("clean_no_arg: dir = {}", package_dir.to_str());
|
2013-06-26 19:42:24 -05:00
|
|
|
command_line_test([~"build"], &package_dir);
|
|
|
|
assert_built_executable_exists(&tmp, "foo");
|
|
|
|
command_line_test([~"clean"], &package_dir);
|
2013-09-20 01:08:47 -05:00
|
|
|
let res = built_executable_in_workspace(&PkgId::new("foo"), &tmp);
|
|
|
|
assert!(!res.as_ref().map_default(false, |m| { os::path_exists(m) }));
|
2013-06-26 19:42:24 -05:00
|
|
|
}
|
|
|
|
|
2013-06-14 20:16:24 -05:00
|
|
|
#[test]
|
|
|
|
fn rust_path_test() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir_for_path = TempDir::new("more_rust").expect("rust_path_test failed");
|
|
|
|
let dir = mk_workspace(dir_for_path.path(), &Path("foo"), &NoVersion);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("dir = {}", dir.to_str());
|
2013-06-26 19:42:24 -05:00
|
|
|
writeFile(&dir.push("main.rs"), "fn main() { let _x = (); }");
|
2013-06-25 21:49:01 -05:00
|
|
|
|
|
|
|
let cwd = os::getcwd();
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("cwd = {}", cwd.to_str());
|
2013-07-31 15:47:32 -05:00
|
|
|
// use command_line_test_with_env
|
2013-08-15 20:36:39 -05:00
|
|
|
command_line_test_with_env([~"install", ~"foo"],
|
|
|
|
&cwd,
|
2013-10-11 08:55:37 -05:00
|
|
|
Some(~[(~"RUST_PATH", dir_for_path.path().to_str())]));
|
|
|
|
assert_executable_exists(dir_for_path.path(), "foo");
|
2013-06-25 21:49:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-09-13 23:41:28 -05:00
|
|
|
#[ignore] // FIXME(#9184) tests can't change the cwd (other tests are sad then)
|
2013-06-25 21:49:01 -05:00
|
|
|
fn rust_path_contents() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = TempDir::new("rust_path").expect("rust_path_contents failed");
|
|
|
|
let abc = &dir.path().push_many([~"A", ~"B", ~"C"]);
|
2013-06-30 22:51:13 -05: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-09-13 23:41:28 -05:00
|
|
|
assert!(os::change_dir(abc));
|
|
|
|
|
|
|
|
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");
|
|
|
|
assert!(p.contains(&cwd));
|
|
|
|
assert!(p.contains(&parent));
|
|
|
|
assert!(p.contains(&grandparent));
|
|
|
|
for a_path in p.iter() {
|
|
|
|
assert!(!a_path.components.is_empty());
|
|
|
|
}
|
2013-06-25 21:49:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_parse() {
|
|
|
|
os::setenv("RUST_PATH", "/a/b/c:/d/e/f:/g/h/i");
|
|
|
|
let paths = rust_path();
|
2013-06-28 11:08:32 -05: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 21:49:01 -05:00
|
|
|
os::unsetenv("RUST_PATH");
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-07-11 20:20:31 -05:00
|
|
|
fn test_list() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = TempDir::new("test_list").expect("test_list failed");
|
|
|
|
let dir = dir.path();
|
2013-07-31 15:47:32 -05:00
|
|
|
let foo = PkgId::new("foo");
|
2013-10-11 08:55:37 -05:00
|
|
|
create_local_package_in(&foo, dir);
|
2013-07-31 15:47:32 -05:00
|
|
|
let bar = PkgId::new("bar");
|
2013-10-11 08:55:37 -05:00
|
|
|
create_local_package_in(&bar, dir);
|
2013-07-31 15:47:32 -05:00
|
|
|
let quux = PkgId::new("quux");
|
2013-10-11 08:55:37 -05:00
|
|
|
create_local_package_in(&quux, dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
|
2013-07-31 15:47:32 -05:00
|
|
|
// list doesn't output very much right now...
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
let env_arg = ~[(~"RUST_PATH", dir.to_str())];
|
|
|
|
let list_output = command_line_test_output_with_env([~"list"], env_arg.clone());
|
2013-07-31 15:47:32 -05:00
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("foo")));
|
2013-07-11 20:20:31 -05:00
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"bar"], dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
let list_output = command_line_test_output_with_env([~"list"], env_arg.clone());
|
2013-07-31 15:47:32 -05:00
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("foo")));
|
|
|
|
assert!(list_output.iter().any(|x| x.starts_with("bar")));
|
2013-07-11 20:20:31 -05:00
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"quux"], dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
let list_output = command_line_test_output_with_env([~"list"], env_arg);
|
2013-07-31 15:47:32 -05:00
|
|
|
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")));
|
2013-07-11 20:20:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-06-14 20:16:24 -05:00
|
|
|
fn install_remove() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = TempDir::new("install_remove").expect("install_remove");
|
|
|
|
let dir = dir.path();
|
2013-07-31 15:47:32 -05:00
|
|
|
let foo = PkgId::new("foo");
|
|
|
|
let bar = PkgId::new("bar");
|
|
|
|
let quux = PkgId::new("quux");
|
2013-10-11 08:55:37 -05:00
|
|
|
create_local_package_in(&foo, dir);
|
|
|
|
create_local_package_in(&bar, dir);
|
|
|
|
create_local_package_in(&quux, dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
let rust_path_to_use = ~[(~"RUST_PATH", dir.to_str())];
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], dir);
|
|
|
|
command_line_test([~"install", ~"bar"], dir);
|
|
|
|
command_line_test([~"install", ~"quux"], dir);
|
2013-07-11 20:20:31 -05: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")));
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"uninstall", ~"foo"], dir);
|
2013-07-11 20:20:31 -05: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")));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[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
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = TempDir::new("install_remove").expect("install_remove");
|
|
|
|
let dir = dir.path();
|
2013-07-31 15:47:32 -05:00
|
|
|
let foo = PkgId::new("foo");
|
2013-10-11 08:55:37 -05:00
|
|
|
create_local_package_in(&foo, dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], dir);
|
|
|
|
command_line_test([~"install", ~"foo"], dir);
|
2013-07-11 20:20:31 -05:00
|
|
|
let mut contents = ~[];
|
|
|
|
let check_dups = |p: &PkgId| {
|
|
|
|
if contents.contains(p) {
|
2013-09-28 01:37:25 -05:00
|
|
|
fail2!("package {} appears in `list` output more than once", p.path.to_str());
|
2013-07-11 20:20:31 -05:00
|
|
|
}
|
|
|
|
else {
|
2013-07-10 16:43:25 -05:00
|
|
|
contents.push((*p).clone());
|
2013-07-11 20:20:31 -05:00
|
|
|
}
|
|
|
|
false
|
|
|
|
};
|
|
|
|
list_installed_packages(check_dups);
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn no_rebuilding() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let p_id = PkgId::new("foo");
|
2013-06-14 20:16:24 -05:00
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
2013-06-14 20:16:24 -05:00
|
|
|
let date = datestamp(&built_library_in_workspace(&p_id,
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace).expect("no_rebuilding"));
|
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
2013-06-14 20:16:24 -05:00
|
|
|
let newdate = datestamp(&built_library_in_workspace(&p_id,
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace).expect("no_rebuilding (2)"));
|
2013-06-14 20:16:24 -05:00
|
|
|
assert_eq!(date, newdate);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn no_rebuilding_dep() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let dep_id = PkgId::new("bar");
|
2013-06-14 20:16:24 -05:00
|
|
|
let workspace = create_local_package_with_dep(&p_id, &dep_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
|
|
|
let bar_lib = lib_output_file_name(workspace, "bar");
|
2013-09-16 21:27:09 -05:00
|
|
|
let bar_date_1 = datestamp(&bar_lib);
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
frob_source_file(workspace, &p_id, "main.rs");
|
2013-09-16 21:27:09 -05:00
|
|
|
|
|
|
|
// Now make `bar` read-only so that subsequent rebuilds of it will fail
|
|
|
|
assert!(chmod_read_only(&bar_lib));
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
match command_line_test_partial([~"build", ~"foo"], workspace) {
|
2013-09-16 21:27:09 -05:00
|
|
|
Success(*) => (), // ok
|
2013-09-28 01:37:25 -05:00
|
|
|
Fail(status) if status == 65 => fail2!("no_rebuilding_dep failed: it tried to rebuild bar"),
|
|
|
|
Fail(_) => fail2!("no_rebuilding_dep failed for some other reason")
|
2013-09-16 21:27:09 -05:00
|
|
|
}
|
2013-09-06 22:29:16 -05:00
|
|
|
|
2013-10-05 15:40:01 -05:00
|
|
|
let bar_date_2 = datestamp(&bar_lib);
|
2013-09-06 22:29:16 -05:00
|
|
|
assert_eq!(bar_date_1, bar_date_2);
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-09-23 19:26:04 -05:00
|
|
|
#[ignore]
|
2013-06-14 20:16:24 -05:00
|
|
|
fn do_rebuild_dep_dates_change() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let dep_id = PkgId::new("bar");
|
2013-06-14 20:16:24 -05:00
|
|
|
let workspace = create_local_package_with_dep(&p_id, &dep_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
|
|
|
let bar_lib_name = lib_output_file_name(workspace, "bar");
|
2013-08-23 13:51:45 -05:00
|
|
|
let bar_date = datestamp(&bar_lib_name);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Datestamp on {} is {:?}", bar_lib_name.to_str(), bar_date);
|
2013-10-11 08:55:37 -05:00
|
|
|
touch_source_file(workspace, &dep_id);
|
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
2013-08-23 13:51:45 -05:00
|
|
|
let new_bar_date = datestamp(&bar_lib_name);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Datestamp on {} is {:?}", bar_lib_name.to_str(), new_bar_date);
|
2013-06-14 20:16:24 -05:00
|
|
|
assert!(new_bar_date > bar_date);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2013-09-23 19:26:04 -05:00
|
|
|
#[ignore]
|
2013-06-14 20:16:24 -05:00
|
|
|
fn do_rebuild_dep_only_contents_change() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let dep_id = PkgId::new("bar");
|
2013-06-14 20:16:24 -05:00
|
|
|
let workspace = create_local_package_with_dep(&p_id, &dep_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
|
|
|
let bar_date = datestamp(&lib_output_file_name(workspace, "bar"));
|
|
|
|
frob_source_file(workspace, &dep_id, "lib.rs");
|
2013-06-14 20:16:24 -05:00
|
|
|
// should adjust the datestamp
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
|
|
|
let new_bar_date = datestamp(&lib_output_file_name(workspace, "bar"));
|
2013-06-14 20:16:24 -05:00
|
|
|
assert!(new_bar_date > bar_date);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_versions() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let workspace = create_local_package(&PkgId::new("foo#0.1"));
|
2013-10-11 08:55:37 -05:00
|
|
|
let _other_workspace = create_local_package(&PkgId::new("foo#0.2"));
|
|
|
|
command_line_test([~"install", ~"foo#0.1"], workspace.path());
|
2013-06-14 20:16:24 -05:00
|
|
|
let output = command_line_test_output([~"list"]);
|
|
|
|
// make sure output includes versions
|
2013-07-04 21:13:26 -05:00
|
|
|
assert!(!output.iter().any(|x| x == &~"foo#0.2"));
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "do not yet implemented")]
|
|
|
|
fn test_build_hooks() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let workspace = create_local_package_with_custom_build_hook(&PkgId::new("foo"),
|
2013-07-09 20:28:00 -05:00
|
|
|
"frob");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"do", ~"foo", ~"frob"], workspace.path());
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "info not yet implemented")]
|
|
|
|
fn test_info() {
|
|
|
|
let expected_info = ~"package foo"; // fill in
|
2013-07-31 15:47:32 -05:00
|
|
|
let workspace = create_local_package(&PkgId::new("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
let output = command_line_test([~"info", ~"foo"], workspace.path());
|
2013-09-05 07:17:24 -05:00
|
|
|
assert_eq!(str::from_utf8(output.output), expected_info);
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_uninstall() {
|
2013-07-31 15:47:32 -05:00
|
|
|
let workspace = create_local_package(&PkgId::new("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"uninstall", ~"foo"], workspace.path());
|
|
|
|
let output = command_line_test([~"list"], workspace.path());
|
2013-09-05 07:17:24 -05:00
|
|
|
assert!(!str::from_utf8(output.output).contains("foo"));
|
2013-06-14 20:16:24 -05:00
|
|
|
}
|
2013-07-24 20:42:14 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_non_numeric_tag() {
|
|
|
|
let temp_pkg_id = git_repo_pkg();
|
2013-08-02 18:59:58 -05:00
|
|
|
let repo = init_git_repo(&temp_pkg_id.path);
|
2013-10-11 08:55:37 -05:00
|
|
|
let repo = repo.path();
|
2013-09-12 20:48:02 -05:00
|
|
|
let repo_subdir = repo.push_many([~"mockgithub.com", ~"catamorphism", ~"test-pkg"]);
|
2013-07-24 20:42:14 -05:00
|
|
|
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);
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", format!("{}\\#testbranch", temp_pkg_id.path.to_str())], repo);
|
2013-07-24 20:42:14 -05:00
|
|
|
let file1 = repo.push_many(["mockgithub.com", "catamorphism",
|
2013-08-02 18:59:58 -05:00
|
|
|
"test-pkg", "testbranch_only"]);
|
|
|
|
let file2 = repo.push_many(["mockgithub.com", "catamorphism", "test-pkg",
|
2013-07-24 20:42:14 -05:00
|
|
|
"master_only"]);
|
2013-07-26 14:31:53 -05:00
|
|
|
assert!(os::path_exists(&file1));
|
2013-07-24 20:42:14 -05:00
|
|
|
assert!(!os::path_exists(&file2));
|
|
|
|
}
|
2013-07-31 15:47:32 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_extern_mod() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = TempDir::new("test_extern_mod").expect("test_extern_mod");
|
|
|
|
let dir = dir.path();
|
2013-07-31 15:47:32 -05:00
|
|
|
let main_file = dir.push("main.rs");
|
2013-10-11 08:55:37 -05:00
|
|
|
let lib_depend_dir = TempDir::new("foo").expect("test_extern_mod");
|
|
|
|
let lib_depend_dir = lib_depend_dir.path();
|
2013-07-31 15:47:32 -05:00
|
|
|
let aux_dir = lib_depend_dir.push_many(["src", "mockgithub.com", "catamorphism", "test_pkg"]);
|
|
|
|
assert!(os::mkdir_recursive(&aux_dir, U_RWX));
|
|
|
|
let aux_pkg_file = aux_dir.push("lib.rs");
|
|
|
|
|
|
|
|
writeFile(&aux_pkg_file, "pub mod bar { pub fn assert_true() { assert!(true); } }\n");
|
|
|
|
assert!(os::path_exists(&aux_pkg_file));
|
|
|
|
|
|
|
|
writeFile(&main_file,
|
|
|
|
"extern mod test = \"mockgithub.com/catamorphism/test_pkg\";\nuse test::bar;\
|
|
|
|
fn main() { bar::assert_true(); }\n");
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"mockgithub.com/catamorphism/test_pkg"], lib_depend_dir);
|
2013-07-31 15:47:32 -05:00
|
|
|
|
2013-09-13 20:04:45 -05:00
|
|
|
let exec_file = dir.push("out");
|
|
|
|
// Be sure to extend the existing environment
|
|
|
|
let env = Some([(~"RUST_PATH", lib_depend_dir.to_str())] + os::env());
|
|
|
|
let rustpkg_exec = rustpkg_exec();
|
|
|
|
let rustc = rustpkg_exec.with_filename("rustc");
|
|
|
|
|
|
|
|
let mut prog = run::Process::new(rustc.to_str(), [main_file.to_str(),
|
|
|
|
~"--sysroot", test_sysroot().to_str(),
|
|
|
|
~"-o", exec_file.to_str()],
|
|
|
|
run::ProcessOptions {
|
|
|
|
env: env,
|
2013-10-11 08:55:37 -05:00
|
|
|
dir: Some(dir),
|
2013-09-13 20:04:45 -05:00
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
let outp = prog.finish_with_output();
|
|
|
|
if outp.status != 0 {
|
2013-09-28 01:37:25 -05:00
|
|
|
fail2!("output was {}, error was {}",
|
2013-09-13 20:04:45 -05:00
|
|
|
str::from_utf8(outp.output),
|
|
|
|
str::from_utf8(outp.error));
|
|
|
|
}
|
|
|
|
assert!(os::path_exists(&exec_file) && is_executable(&exec_file));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_extern_mod_simpler() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = TempDir::new("test_extern_mod_simpler").expect("test_extern_mod_simpler");
|
|
|
|
let dir = dir.path();
|
2013-09-13 20:04:45 -05:00
|
|
|
let main_file = dir.push("main.rs");
|
2013-10-11 08:55:37 -05:00
|
|
|
let lib_depend_dir = TempDir::new("foo").expect("test_extern_mod_simpler");
|
|
|
|
let lib_depend_dir = lib_depend_dir.path();
|
2013-09-13 20:04:45 -05:00
|
|
|
let aux_dir = lib_depend_dir.push_many(["src", "rust-awesomeness"]);
|
|
|
|
assert!(os::mkdir_recursive(&aux_dir, U_RWX));
|
|
|
|
let aux_pkg_file = aux_dir.push("lib.rs");
|
|
|
|
|
|
|
|
writeFile(&aux_pkg_file, "pub mod bar { pub fn assert_true() { assert!(true); } }\n");
|
|
|
|
assert!(os::path_exists(&aux_pkg_file));
|
|
|
|
|
|
|
|
writeFile(&main_file,
|
|
|
|
"extern mod test = \"rust-awesomeness\";\nuse test::bar;\
|
|
|
|
fn main() { bar::assert_true(); }\n");
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"rust-awesomeness"], lib_depend_dir);
|
2013-09-13 20:04:45 -05:00
|
|
|
|
2013-07-31 15:47:32 -05:00
|
|
|
let exec_file = dir.push("out");
|
|
|
|
// Be sure to extend the existing environment
|
|
|
|
let env = Some([(~"RUST_PATH", lib_depend_dir.to_str())] + os::env());
|
|
|
|
let rustpkg_exec = rustpkg_exec();
|
|
|
|
let rustc = rustpkg_exec.with_filename("rustc");
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("RUST_PATH={} {} {} \n --sysroot {} -o {}",
|
2013-07-31 15:47:32 -05:00
|
|
|
lib_depend_dir.to_str(),
|
|
|
|
rustc.to_str(),
|
|
|
|
main_file.to_str(),
|
|
|
|
test_sysroot().to_str(),
|
|
|
|
exec_file.to_str());
|
|
|
|
|
2013-08-29 16:20:48 -05:00
|
|
|
let mut prog = run::Process::new(rustc.to_str(), [main_file.to_str(),
|
|
|
|
~"--sysroot", test_sysroot().to_str(),
|
|
|
|
~"-o", exec_file.to_str()],
|
|
|
|
run::ProcessOptions {
|
2013-08-13 17:56:17 -05:00
|
|
|
env: env,
|
2013-10-11 08:55:37 -05:00
|
|
|
dir: Some(dir),
|
2013-07-31 15:47:32 -05:00
|
|
|
in_fd: None,
|
|
|
|
out_fd: None,
|
|
|
|
err_fd: None
|
|
|
|
});
|
|
|
|
let outp = prog.finish_with_output();
|
|
|
|
if outp.status != 0 {
|
2013-09-28 01:37:25 -05:00
|
|
|
fail2!("output was {}, error was {}",
|
2013-09-05 07:17:24 -05:00
|
|
|
str::from_utf8(outp.output),
|
|
|
|
str::from_utf8(outp.error));
|
2013-07-31 15:47:32 -05:00
|
|
|
}
|
|
|
|
assert!(os::path_exists(&exec_file) && is_executable(&exec_file));
|
|
|
|
}
|
|
|
|
|
2013-08-21 19:12:32 -05:00
|
|
|
#[test]
|
|
|
|
fn test_import_rustpkg() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-12 20:48:02 -05:00
|
|
|
writeFile(&workspace.push_many([~"src", ~"foo-0.1", ~"pkg.rs"]),
|
2013-08-21 19:12:32 -05:00
|
|
|
"extern mod rustpkg; fn main() {}");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("workspace = {}", workspace.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
assert!(os::path_exists(&target_build_dir(workspace).push("foo").push(format!("pkg{}",
|
2013-08-21 19:12:32 -05:00
|
|
|
os::EXE_SUFFIX))));
|
|
|
|
}
|
|
|
|
|
2013-08-21 20:04:08 -05:00
|
|
|
#[test]
|
|
|
|
fn test_macro_pkg_script() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-12 20:48:02 -05:00
|
|
|
writeFile(&workspace.push_many([~"src", ~"foo-0.1", ~"pkg.rs"]),
|
2013-09-28 01:37:25 -05:00
|
|
|
"extern mod rustpkg; fn main() { debug2!(\"Hi\"); }");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"build", ~"foo"], workspace);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("workspace = {}", workspace.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
assert!(os::path_exists(&target_build_dir(workspace).push("foo").push(format!("pkg{}",
|
2013-08-21 20:04:08 -05:00
|
|
|
os::EXE_SUFFIX))));
|
|
|
|
}
|
|
|
|
|
2013-08-23 13:51:45 -05:00
|
|
|
#[test]
|
|
|
|
fn multiple_workspaces() {
|
|
|
|
// Make a package foo; build/install in directory A
|
|
|
|
// Copy the exact same package into directory B and install it
|
|
|
|
// Set the RUST_PATH to A:B
|
|
|
|
// Make a third package that uses foo, make sure we can build/install it
|
2013-10-11 08:55:37 -05:00
|
|
|
let (a_loc, _pkg_dir) = mk_temp_workspace(&Path("foo"), &NoVersion);
|
|
|
|
let (b_loc, _pkg_dir) = mk_temp_workspace(&Path("foo"), &NoVersion);
|
|
|
|
let (a_loc, b_loc) = (a_loc.path(), b_loc.path());
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Trying to install foo in {}", a_loc.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], a_loc);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Trying to install foo in {}", b_loc.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"foo"], b_loc);
|
2013-09-28 01:37:25 -05:00
|
|
|
let env = Some(~[(~"RUST_PATH", format!("{}:{}", a_loc.to_str(), b_loc.to_str()))]);
|
2013-08-23 13:51:45 -05:00
|
|
|
let c_loc = create_local_package_with_dep(&PkgId::new("bar"), &PkgId::new("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test_with_env([~"install", ~"bar"], c_loc.path(), env);
|
2013-08-23 13:51:45 -05:00
|
|
|
}
|
|
|
|
|
2013-08-28 16:52:37 -05:00
|
|
|
fn rust_path_hack_test(hack_flag: bool) {
|
|
|
|
/*
|
|
|
|
Make a workspace containing a pkg foo [A]
|
|
|
|
Make a second, empty workspace [B]
|
|
|
|
Set RUST_PATH to B:A
|
|
|
|
rustpkg install foo
|
|
|
|
make sure built files for foo are in B
|
|
|
|
make sure nothing gets built into A or A/../build[lib,bin]
|
|
|
|
*/
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let dest_workspace = mk_empty_workspace(&Path("bar"), &NoVersion, "dest_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH",
|
2013-09-28 01:37:25 -05:00
|
|
|
format!("{}:{}",
|
|
|
|
dest_workspace.to_str(),
|
|
|
|
workspace.push_many(["src", "foo-0.1"]).to_str()))]);
|
2013-08-28 16:52:37 -05:00
|
|
|
command_line_test_with_env(~[~"install"] + if hack_flag { ~[~"--rust-path-hack"] } else { ~[] } +
|
2013-10-11 08:55:37 -05:00
|
|
|
~[~"foo"], dest_workspace, rust_path);
|
|
|
|
assert_lib_exists(dest_workspace, &Path("foo"), NoVersion);
|
|
|
|
assert_executable_exists(dest_workspace, "foo");
|
|
|
|
assert_built_library_exists(dest_workspace, "foo");
|
|
|
|
assert_built_executable_exists(dest_workspace, "foo");
|
|
|
|
assert!(!lib_exists(workspace, &Path("foo"), NoVersion));
|
|
|
|
assert!(!executable_exists(workspace, "foo"));
|
|
|
|
assert!(!built_library_exists(workspace, "foo"));
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
2013-08-28 16:52:37 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_rust_path_can_contain_package_dirs_with_flag() {
|
|
|
|
/*
|
|
|
|
Test that the temporary hack added for bootstrapping Servo builds
|
|
|
|
works. That is: if you add $FOO/src/some_pkg to the RUST_PATH,
|
|
|
|
it will find the sources in some_pkg, build them, and install them
|
|
|
|
into the first entry in the RUST_PATH.
|
|
|
|
|
|
|
|
When the hack is removed, we should change this to a should_fail test.
|
|
|
|
*/
|
|
|
|
rust_path_hack_test(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[should_fail]
|
|
|
|
fn test_rust_path_can_contain_package_dirs_without_flag() {
|
|
|
|
rust_path_hack_test(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_hack_cwd() {
|
|
|
|
// Same as rust_path_hack_test, but the CWD is the dir to build out of
|
2013-10-11 08:55:37 -05:00
|
|
|
let cwd = TempDir::new("foo").expect("rust_path_hack_cwd");
|
|
|
|
let cwd = cwd.path().push("foo");
|
2013-09-24 14:10:44 -05:00
|
|
|
assert!(os::mkdir_recursive(&cwd, U_RWX));
|
2013-08-28 16:52:37 -05:00
|
|
|
writeFile(&cwd.push("lib.rs"), "pub fn f() { }");
|
|
|
|
|
|
|
|
let dest_workspace = mk_empty_workspace(&Path("bar"), &NoVersion, "dest_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH", dest_workspace.to_str())]);
|
|
|
|
command_line_test_with_env([~"install", ~"--rust-path-hack", ~"foo"], &cwd, rust_path);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Checking that foo exists in {}", dest_workspace.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_lib_exists(dest_workspace, &Path("foo"), NoVersion);
|
|
|
|
assert_built_library_exists(dest_workspace, "foo");
|
2013-09-12 15:56:11 -05:00
|
|
|
assert!(!lib_exists(&cwd, &Path("foo"), NoVersion));
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(!built_library_exists(&cwd, "foo"));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_hack_multi_path() {
|
|
|
|
// Same as rust_path_hack_test, but with a more complex package ID
|
2013-10-11 08:55:37 -05:00
|
|
|
let cwd = TempDir::new("pkg_files").expect("rust_path_hack_cwd");
|
|
|
|
let subdir = cwd.path().push_many([~"foo", ~"bar", ~"quux"]);
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(os::mkdir_recursive(&subdir, U_RWX));
|
|
|
|
writeFile(&subdir.push("lib.rs"), "pub fn f() { }");
|
|
|
|
let name = ~"foo/bar/quux";
|
|
|
|
|
|
|
|
let dest_workspace = mk_empty_workspace(&Path("bar"), &NoVersion, "dest_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH", dest_workspace.to_str())]);
|
|
|
|
command_line_test_with_env([~"install", ~"--rust-path-hack", name.clone()], &subdir, rust_path);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Checking that {} exists in {}", name, dest_workspace.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_lib_exists(dest_workspace, &Path("quux"), NoVersion);
|
|
|
|
assert_built_library_exists(dest_workspace, name);
|
2013-09-12 15:56:11 -05:00
|
|
|
assert!(!lib_exists(&subdir, &Path("quux"), NoVersion));
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(!built_library_exists(&subdir, name));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_hack_install_no_arg() {
|
|
|
|
// Same as rust_path_hack_cwd, but making rustpkg infer the pkg id
|
2013-10-11 08:55:37 -05:00
|
|
|
let cwd = TempDir::new("pkg_files").expect("rust_path_hack_install_no_arg");
|
|
|
|
let cwd = cwd.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let source_dir = cwd.push("foo");
|
|
|
|
assert!(make_dir_rwx(&source_dir));
|
|
|
|
writeFile(&source_dir.push("lib.rs"), "pub fn f() { }");
|
|
|
|
|
|
|
|
let dest_workspace = mk_empty_workspace(&Path("bar"), &NoVersion, "dest_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH", dest_workspace.to_str())]);
|
|
|
|
command_line_test_with_env([~"install", ~"--rust-path-hack"], &source_dir, rust_path);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Checking that foo exists in {}", dest_workspace.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_lib_exists(dest_workspace, &Path("foo"), NoVersion);
|
|
|
|
assert_built_library_exists(dest_workspace, "foo");
|
2013-09-12 15:56:11 -05:00
|
|
|
assert!(!lib_exists(&source_dir, &Path("foo"), NoVersion));
|
2013-10-11 08:55:37 -05:00
|
|
|
assert!(!built_library_exists(cwd, "foo"));
|
2013-08-28 16:52:37 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_hack_build_no_arg() {
|
|
|
|
// Same as rust_path_hack_install_no_arg, but building instead of installing
|
2013-10-11 08:55:37 -05:00
|
|
|
let cwd = TempDir::new("pkg_files").expect("rust_path_hack_build_no_arg");
|
|
|
|
let source_dir = cwd.path().push("foo");
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(make_dir_rwx(&source_dir));
|
|
|
|
writeFile(&source_dir.push("lib.rs"), "pub fn f() { }");
|
|
|
|
|
|
|
|
let dest_workspace = mk_empty_workspace(&Path("bar"), &NoVersion, "dest_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH", dest_workspace.to_str())]);
|
|
|
|
command_line_test_with_env([~"build", ~"--rust-path-hack"], &source_dir, rust_path);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Checking that foo exists in {}", dest_workspace.to_str());
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_built_library_exists(dest_workspace, "foo");
|
2013-08-28 16:52:37 -05:00
|
|
|
assert!(!built_library_exists(&source_dir, "foo"));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rust_path_install_target() {
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir_for_path = TempDir::new(
|
2013-08-28 16:52:37 -05:00
|
|
|
"source_workspace").expect("rust_path_install_target failed");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir = mk_workspace(dir_for_path.path(), &Path("foo"), &NoVersion);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("dir = {}", dir.to_str());
|
2013-08-28 16:52:37 -05:00
|
|
|
writeFile(&dir.push("main.rs"), "fn main() { let _x = (); }");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir_to_install_to = TempDir::new(
|
2013-08-28 16:52:37 -05:00
|
|
|
"dest_workspace").expect("rust_path_install_target failed");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dir_to_install_to = dir_to_install_to.path();
|
2013-08-28 16:52:37 -05:00
|
|
|
let dir = dir.pop().pop();
|
|
|
|
|
2013-09-28 01:37:25 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH", format!("{}:{}", dir_to_install_to.to_str(),
|
2013-08-28 16:52:37 -05:00
|
|
|
dir.to_str()))]);
|
|
|
|
let cwd = os::getcwd();
|
|
|
|
command_line_test_with_env([~"install", ~"foo"],
|
|
|
|
&cwd,
|
|
|
|
rust_path);
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_executable_exists(dir_to_install_to, "foo");
|
2013-08-28 16:52:37 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-09-10 13:41:05 -05:00
|
|
|
#[test]
|
|
|
|
fn sysroot_flag() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
// no-op sysroot setting; I'm not sure how else to test this
|
|
|
|
command_line_test([~"--sysroot",
|
|
|
|
test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert_built_executable_exists(workspace, "foo");
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_flag_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"--no-link",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(object_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_flag_fail() {
|
|
|
|
// --no-link shouldn't be accepted for install
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"--no-link",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn notrans_flag_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
let flags_to_test = [~"--no-trans", ~"--parse-only",
|
|
|
|
~"--pretty", ~"-S"];
|
|
|
|
|
|
|
|
for flag in flags_to_test.iter() {
|
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
flag.clone(),
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
2013-09-10 13:41:05 -05:00
|
|
|
// Ideally we'd test that rustpkg actually succeeds, but
|
|
|
|
// since task failure doesn't set the exit code properly,
|
|
|
|
// we can't tell
|
2013-10-11 08:55:37 -05:00
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn notrans_flag_fail() {
|
|
|
|
// --no-trans shouldn't be accepted for install
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
let flags_to_test = [~"--no-trans", ~"--parse-only",
|
|
|
|
~"--pretty", ~"-S"];
|
|
|
|
for flag in flags_to_test.iter() {
|
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
flag.clone(),
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
2013-09-10 13:41:05 -05:00
|
|
|
// Ideally we'd test that rustpkg actually fails, but
|
|
|
|
// since task failure doesn't set the exit code properly,
|
|
|
|
// we can't tell
|
2013-10-11 08:55:37 -05:00
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(!lib_exists(workspace, &Path("foo"), NoVersion));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dash_S() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"-S",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(assembly_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dash_S_fail() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"-S",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(!assembly_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_cfg_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
// If the cfg flag gets messed up, this won't compile
|
|
|
|
writeFile(&workspace.push_many(["src", "foo-0.1", "main.rs"]),
|
|
|
|
"#[cfg(quux)] fn main() {}");
|
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"--cfg",
|
|
|
|
~"quux",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert_built_executable_exists(workspace, "foo");
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_cfg_fail() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
writeFile(&workspace.push_many(["src", "foo-0.1", "main.rs"]),
|
|
|
|
"#[cfg(quux)] fn main() {}");
|
2013-09-16 21:27:09 -05:00
|
|
|
match command_line_test_partial([test_sysroot().to_str(),
|
2013-09-10 13:41:05 -05:00
|
|
|
~"build",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace) {
|
2013-09-28 01:37:25 -05:00
|
|
|
Success(*) => fail2!("test_cfg_fail failed"),
|
2013-09-16 21:27:09 -05:00
|
|
|
_ => ()
|
|
|
|
}
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_emit_llvm_S_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"-S", ~"--emit-llvm",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(llvm_assembly_file_exists(workspace, "foo"));
|
|
|
|
assert!(!assembly_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_emit_llvm_S_fail() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"-S", ~"--emit-llvm",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(!llvm_assembly_file_exists(workspace, "foo"));
|
|
|
|
assert!(!assembly_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_emit_llvm_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"--emit-llvm",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(llvm_bitcode_file_exists(workspace, "foo"));
|
|
|
|
assert!(!assembly_file_exists(workspace, "foo"));
|
|
|
|
assert!(!llvm_assembly_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_emit_llvm_fail() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"--emit-llvm",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(!built_executable_exists(workspace, "foo"));
|
|
|
|
assert!(!object_file_exists(workspace, "foo"));
|
|
|
|
assert!(!llvm_bitcode_file_exists(workspace, "foo"));
|
|
|
|
assert!(!llvm_assembly_file_exists(workspace, "foo"));
|
|
|
|
assert!(!assembly_file_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_linker_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
let matches = getopts([], optgroups());
|
|
|
|
let options = build_session_options(@"rustpkg",
|
|
|
|
matches.get_ref(),
|
2013-09-18 20:18:45 -05:00
|
|
|
@diagnostic::DefaultEmitter as
|
|
|
|
@diagnostic::Emitter);
|
|
|
|
let sess = build_session(options,
|
|
|
|
@diagnostic::DefaultEmitter as
|
|
|
|
@diagnostic::Emitter);
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"--linker",
|
|
|
|
get_cc_prog(sess),
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert_executable_exists(workspace, "foo");
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_build_install_flags_fail() {
|
|
|
|
// The following flags can only be used with build or install:
|
|
|
|
let forbidden = [~[~"--linker", ~"ld"],
|
|
|
|
~[~"--link-args", ~"quux"],
|
|
|
|
~[~"-O"],
|
|
|
|
~[~"--opt-level", ~"2"],
|
|
|
|
~[~"--save-temps"],
|
|
|
|
~[~"--target", host_triple()],
|
|
|
|
~[~"--target-cpu", ~"generic"],
|
|
|
|
~[~"-Z", ~"--time-passes"]];
|
|
|
|
for flag in forbidden.iter() {
|
|
|
|
let output = command_line_test_output([test_sysroot().to_str(),
|
|
|
|
~"list"] + *flag);
|
|
|
|
assert!(output.len() > 1);
|
|
|
|
assert!(output[1].find_str("can only be used with").is_some());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_optimized_build() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-10 13:41:05 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"-O",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(built_executable_exists(workspace, "foo"));
|
2013-09-10 13:41:05 -05:00
|
|
|
}
|
2013-08-28 16:52:37 -05:00
|
|
|
|
2013-09-12 15:56:11 -05:00
|
|
|
fn pkgid_pointing_to_subdir() {
|
|
|
|
// The actual repo is mockgithub.com/mozilla/some_repo
|
|
|
|
// rustpkg should recognize that and treat the part after some_repo/ as a subdir
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = TempDir::new("parent_repo").expect("Couldn't create temp dir");
|
|
|
|
let workspace = workspace.path();
|
2013-09-12 15:56:11 -05:00
|
|
|
assert!(os::mkdir_recursive(&workspace.push_many([~"src", ~"mockgithub.com",
|
|
|
|
~"mozilla", ~"some_repo"]), U_RWX));
|
|
|
|
|
|
|
|
let foo_dir = workspace.push_many([~"src", ~"mockgithub.com", ~"mozilla", ~"some_repo",
|
|
|
|
~"extras", ~"foo"]);
|
|
|
|
let bar_dir = workspace.push_many([~"src", ~"mockgithub.com", ~"mozilla", ~"some_repo",
|
|
|
|
~"extras", ~"bar"]);
|
|
|
|
assert!(os::mkdir_recursive(&foo_dir, U_RWX));
|
|
|
|
assert!(os::mkdir_recursive(&bar_dir, U_RWX));
|
|
|
|
writeFile(&foo_dir.push("lib.rs"), "pub fn f() {}");
|
|
|
|
writeFile(&bar_dir.push("lib.rs"), "pub fn g() {}");
|
|
|
|
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("Creating a file in {}", workspace.to_str());
|
2013-09-12 15:56:11 -05:00
|
|
|
let testpkg_dir = workspace.push_many([~"src", ~"testpkg-0.1"]);
|
|
|
|
assert!(os::mkdir_recursive(&testpkg_dir, U_RWX));
|
|
|
|
|
|
|
|
writeFile(&testpkg_dir.push("main.rs"),
|
|
|
|
"extern mod foo = \"mockgithub.com/mozilla/some_repo/extras/foo\";\n
|
|
|
|
extern mod bar = \"mockgithub.com/mozilla/some_repo/extras/bar\";\n
|
|
|
|
use foo::f; use bar::g; \n
|
|
|
|
fn main() { f(); g(); }");
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"testpkg"], workspace);
|
|
|
|
assert_executable_exists(workspace, "testpkg");
|
2013-09-12 15:56:11 -05:00
|
|
|
}
|
|
|
|
|
2013-09-11 01:25:31 -05:00
|
|
|
fn test_recursive_deps() {
|
|
|
|
let a_id = PkgId::new("a");
|
|
|
|
let b_id = PkgId::new("b");
|
|
|
|
let c_id = PkgId::new("c");
|
|
|
|
let b_workspace = create_local_package_with_dep(&b_id, &c_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let b_workspace = b_workspace.path();
|
2013-09-11 01:25:31 -05:00
|
|
|
writeFile(&b_workspace.push("src").push("c-0.1").push("lib.rs"),
|
|
|
|
"pub fn g() {}");
|
|
|
|
let a_workspace = create_local_package(&a_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let a_workspace = a_workspace.path();
|
2013-09-11 01:25:31 -05:00
|
|
|
writeFile(&a_workspace.push("src").push("a-0.1").push("main.rs"),
|
|
|
|
"extern mod b; use b::f; fn main() { f(); }");
|
|
|
|
writeFile(&b_workspace.push("src").push("b-0.1").push("lib.rs"),
|
|
|
|
"extern mod c; use c::g; pub fn f() { g(); }");
|
|
|
|
let environment = Some(~[(~"RUST_PATH", b_workspace.to_str())]);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("RUST_PATH={}", b_workspace.to_str());
|
2013-09-11 01:25:31 -05:00
|
|
|
command_line_test_with_env([~"install", ~"a"],
|
2013-10-11 08:55:37 -05:00
|
|
|
a_workspace,
|
2013-09-11 01:25:31 -05:00
|
|
|
environment);
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_lib_exists(a_workspace, &Path("a"), NoVersion);
|
|
|
|
assert_lib_exists(b_workspace, &Path("b"), NoVersion);
|
|
|
|
assert_lib_exists(b_workspace, &Path("c"), NoVersion);
|
2013-09-11 01:25:31 -05:00
|
|
|
}
|
|
|
|
|
2013-09-12 18:13:30 -05:00
|
|
|
#[test]
|
|
|
|
fn test_install_to_rust_path() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let second_workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let second_workspace = second_workspace.path();
|
2013-09-12 18:13:30 -05:00
|
|
|
let first_workspace = mk_empty_workspace(&Path("p"), &NoVersion, "dest");
|
2013-10-11 08:55:37 -05:00
|
|
|
let first_workspace = first_workspace.path();
|
2013-09-12 18:13:30 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH",
|
2013-09-28 01:37:25 -05:00
|
|
|
format!("{}:{}", first_workspace.to_str(),
|
2013-09-12 18:13:30 -05:00
|
|
|
second_workspace.to_str()))]);
|
2013-09-28 01:37:25 -05:00
|
|
|
debug2!("RUST_PATH={}:{}", first_workspace.to_str(), second_workspace.to_str());
|
2013-09-12 18:13:30 -05:00
|
|
|
command_line_test_with_env([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"foo"],
|
|
|
|
&os::getcwd(), rust_path);
|
2013-10-11 08:55:37 -05:00
|
|
|
assert!(!built_executable_exists(first_workspace, "foo"));
|
|
|
|
assert!(built_executable_exists(second_workspace, "foo"));
|
|
|
|
assert_executable_exists(first_workspace, "foo");
|
|
|
|
assert!(!executable_exists(second_workspace, "foo"));
|
2013-09-12 18:13:30 -05:00
|
|
|
}
|
|
|
|
|
2013-09-12 21:29:21 -05:00
|
|
|
fn test_target_specific_build_dir() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-12 21:29:21 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"build",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
|
|
|
assert!(os::path_is_dir(&target_build_dir(workspace)));
|
|
|
|
assert!(built_executable_exists(workspace, "foo"));
|
2013-09-12 21:29:21 -05:00
|
|
|
assert!(os::list_dir(&workspace.push("build")).len() == 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_target_specific_install_dir() {
|
|
|
|
let p_id = PkgId::new("foo");
|
|
|
|
let workspace = create_local_package(&p_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-12 21:29:21 -05:00
|
|
|
command_line_test([test_sysroot().to_str(),
|
|
|
|
~"install",
|
|
|
|
~"foo"],
|
2013-10-11 08:55:37 -05:00
|
|
|
workspace);
|
2013-09-12 21:29:21 -05:00
|
|
|
assert!(os::path_is_dir(&workspace.push("lib").push(host_triple())));
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_lib_exists(workspace, &Path("foo"), NoVersion);
|
2013-09-12 21:29:21 -05:00
|
|
|
assert!(os::list_dir(&workspace.push("lib")).len() == 1);
|
|
|
|
assert!(os::path_is_dir(&workspace.push("bin")));
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_executable_exists(workspace, "foo");
|
2013-09-12 21:29:21 -05:00
|
|
|
}
|
|
|
|
|
2013-09-16 21:27:09 -05:00
|
|
|
#[test]
|
2013-10-05 15:40:01 -05:00
|
|
|
#[ignore(reason = "See #7240")]
|
2013-09-16 21:27:09 -05:00
|
|
|
fn test_dependencies_terminate() {
|
|
|
|
let b_id = PkgId::new("b");
|
|
|
|
let workspace = create_local_package(&b_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-16 21:27:09 -05:00
|
|
|
let b_dir = workspace.push_many([~"src", ~"b-0.1"]);
|
|
|
|
let b_subdir = b_dir.push("test");
|
|
|
|
assert!(os::mkdir_recursive(&b_subdir, U_RWX));
|
|
|
|
writeFile(&b_subdir.push("test.rs"),
|
|
|
|
"extern mod b; use b::f; #[test] fn g() { f() }");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"b"], workspace);
|
2013-09-16 21:27:09 -05:00
|
|
|
}
|
|
|
|
|
2013-09-17 20:23:34 -05:00
|
|
|
#[test]
|
|
|
|
fn install_after_build() {
|
|
|
|
let b_id = PkgId::new("b");
|
|
|
|
let workspace = create_local_package(&b_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
|
|
|
command_line_test([~"build", ~"b"], workspace);
|
|
|
|
command_line_test([~"install", ~"b"], workspace);
|
|
|
|
assert_executable_exists(workspace, b_id.short_name);
|
|
|
|
assert_lib_exists(workspace, &b_id.path, NoVersion);
|
2013-09-17 20:23:34 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn reinstall() {
|
|
|
|
let b = PkgId::new("b");
|
|
|
|
let workspace = create_local_package(&b);
|
2013-10-11 08:55:37 -05:00
|
|
|
let workspace = workspace.path();
|
2013-09-17 20:23:34 -05:00
|
|
|
// 1. Install, then remove executable file, then install again,
|
|
|
|
// and make sure executable was re-installed
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"b"], workspace);
|
|
|
|
assert_executable_exists(workspace, b.short_name);
|
|
|
|
assert_lib_exists(workspace, &b.path, NoVersion);
|
|
|
|
remove_executable_file(&b, workspace);
|
|
|
|
command_line_test([~"install", ~"b"], workspace);
|
|
|
|
assert_executable_exists(workspace, b.short_name);
|
2013-09-17 20:23:34 -05:00
|
|
|
// 2. Build, then remove build executable file, then build again,
|
|
|
|
// and make sure executable was re-built.
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"build", ~"b"], workspace);
|
|
|
|
remove_built_executable_file(&b, workspace);
|
|
|
|
command_line_test([~"build", ~"b"], workspace);
|
|
|
|
assert_built_executable_exists(workspace, b.short_name);
|
2013-09-17 20:23:34 -05:00
|
|
|
// 3. Install, then remove both executable and built executable,
|
|
|
|
// then install again, make sure both were recreated
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", ~"b"], workspace);
|
|
|
|
remove_executable_file(&b, workspace);
|
|
|
|
remove_built_executable_file(&b, workspace);
|
|
|
|
command_line_test([~"install", ~"b"], workspace);
|
|
|
|
assert_executable_exists(workspace, b.short_name);
|
|
|
|
assert_built_executable_exists(workspace, b.short_name);
|
2013-09-17 20:23:34 -05:00
|
|
|
}
|
|
|
|
|
2013-09-24 14:10:44 -05:00
|
|
|
#[test]
|
|
|
|
fn correct_package_name_with_rust_path_hack() {
|
|
|
|
/*
|
|
|
|
Set rust_path_hack flag
|
|
|
|
|
|
|
|
Try to install bar
|
|
|
|
Check that:
|
|
|
|
- no output gets produced in any workspace
|
|
|
|
- there's an error
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Set RUST_PATH to something containing only the sources for foo
|
|
|
|
let foo_id = PkgId::new("foo");
|
|
|
|
let bar_id = PkgId::new("bar");
|
|
|
|
let foo_workspace = create_local_package(&foo_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let foo_workspace = foo_workspace.path();
|
2013-09-24 14:10:44 -05:00
|
|
|
let dest_workspace = mk_empty_workspace(&Path("bar"), &NoVersion, "dest_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-09-24 14:10:44 -05:00
|
|
|
|
|
|
|
writeFile(&dest_workspace.push_many(["src", "bar-0.1", "main.rs"]),
|
|
|
|
"extern mod blat; fn main() { let _x = (); }");
|
|
|
|
|
2013-09-28 01:37:25 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH", format!("{}:{}", dest_workspace.to_str(),
|
2013-09-24 14:10:44 -05:00
|
|
|
foo_workspace.push_many(["src", "foo-0.1"]).to_str()))]);
|
|
|
|
// bar doesn't exist, but we want to make sure rustpkg doesn't think foo is bar
|
|
|
|
command_line_test_with_env([~"install", ~"--rust-path-hack", ~"bar"],
|
2013-10-11 08:55:37 -05:00
|
|
|
dest_workspace, rust_path);
|
|
|
|
assert!(!executable_exists(dest_workspace, "bar"));
|
|
|
|
assert!(!lib_exists(dest_workspace, &bar_id.path.clone(), bar_id.version.clone()));
|
|
|
|
assert!(!executable_exists(dest_workspace, "foo"));
|
|
|
|
assert!(!lib_exists(dest_workspace, &foo_id.path.clone(), foo_id.version.clone()));
|
|
|
|
assert!(!executable_exists(foo_workspace, "bar"));
|
|
|
|
assert!(!lib_exists(foo_workspace, &bar_id.path.clone(), bar_id.version.clone()));
|
|
|
|
assert!(!executable_exists(foo_workspace, "foo"));
|
|
|
|
assert!(!lib_exists(foo_workspace, &foo_id.path.clone(), foo_id.version.clone()));
|
2013-09-24 14:10:44 -05:00
|
|
|
}
|
|
|
|
|
2013-09-26 18:04:49 -05:00
|
|
|
#[test]
|
|
|
|
fn test_rustpkg_test_creates_exec() {
|
|
|
|
let foo_id = PkgId::new("foo");
|
|
|
|
let foo_workspace = create_local_package(&foo_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let foo_workspace = foo_workspace.path();
|
2013-09-26 18:04:49 -05:00
|
|
|
writeFile(&foo_workspace.push_many(["src", "foo-0.1", "test.rs"]),
|
|
|
|
"#[test] fn f() { assert!('a' == 'a'); }");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"test", ~"foo"], foo_workspace);
|
|
|
|
assert!(test_executable_exists(foo_workspace, "foo"));
|
2013-09-26 18:04:49 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_rustpkg_test_output() {
|
|
|
|
let workspace = create_local_package_with_test(&PkgId::new("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
let output = command_line_test([~"test", ~"foo"], workspace.path());
|
2013-09-26 18:04:49 -05:00
|
|
|
let output_str = str::from_utf8(output.output);
|
2013-09-30 19:31:59 -05:00
|
|
|
// The first two assertions are separate because test output may
|
|
|
|
// contain color codes, which could appear between "test f" and "ok".
|
|
|
|
assert!(output_str.contains("test f"));
|
|
|
|
assert!(output_str.contains("ok"));
|
|
|
|
assert!(output_str.contains("1 passed; 0 failed; 0 ignored; 0 measured"));
|
2013-09-26 18:04:49 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[ignore(reason = "See issue #9441")]
|
|
|
|
fn test_rebuild_when_needed() {
|
|
|
|
let foo_id = PkgId::new("foo");
|
|
|
|
let foo_workspace = create_local_package(&foo_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let foo_workspace = foo_workspace.path();
|
2013-09-26 18:04:49 -05:00
|
|
|
let test_crate = foo_workspace.push_many(["src", "foo-0.1", "test.rs"]);
|
|
|
|
writeFile(&test_crate, "#[test] fn f() { assert!('a' == 'a'); }");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"test", ~"foo"], foo_workspace);
|
|
|
|
assert!(test_executable_exists(foo_workspace, "foo"));
|
2013-09-26 18:04:49 -05:00
|
|
|
let test_executable = built_test_in_workspace(&foo_id,
|
2013-10-11 08:55:37 -05:00
|
|
|
foo_workspace).expect("test_rebuild_when_needed failed");
|
|
|
|
frob_source_file(foo_workspace, &foo_id, "test.rs");
|
2013-09-26 18:04:49 -05:00
|
|
|
chmod_read_only(&test_executable);
|
2013-10-11 08:55:37 -05:00
|
|
|
match command_line_test_partial([~"test", ~"foo"], foo_workspace) {
|
2013-09-28 01:37:25 -05:00
|
|
|
Success(*) => fail2!("test_rebuild_when_needed didn't rebuild"),
|
2013-09-26 18:04:49 -05:00
|
|
|
Fail(status) if status == 65 => (), // ok
|
2013-09-28 01:37:25 -05:00
|
|
|
Fail(_) => fail2!("test_rebuild_when_needed failed for some other reason")
|
2013-09-26 18:04:49 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_no_rebuilding() {
|
|
|
|
let foo_id = PkgId::new("foo");
|
|
|
|
let foo_workspace = create_local_package(&foo_id);
|
2013-10-11 08:55:37 -05:00
|
|
|
let foo_workspace = foo_workspace.path();
|
2013-09-26 18:04:49 -05:00
|
|
|
let test_crate = foo_workspace.push_many(["src", "foo-0.1", "test.rs"]);
|
|
|
|
writeFile(&test_crate, "#[test] fn f() { assert!('a' == 'a'); }");
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"test", ~"foo"], foo_workspace);
|
|
|
|
assert!(test_executable_exists(foo_workspace, "foo"));
|
2013-09-26 18:04:49 -05:00
|
|
|
let test_executable = built_test_in_workspace(&foo_id,
|
2013-10-11 08:55:37 -05:00
|
|
|
foo_workspace).expect("test_no_rebuilding failed");
|
2013-09-26 18:04:49 -05:00
|
|
|
chmod_read_only(&test_executable);
|
2013-10-11 08:55:37 -05:00
|
|
|
match command_line_test_partial([~"test", ~"foo"], foo_workspace) {
|
2013-09-26 18:04:49 -05:00
|
|
|
Success(*) => (), // ok
|
2013-09-28 01:37:25 -05:00
|
|
|
Fail(status) if status == 65 => fail2!("test_no_rebuilding failed: it rebuilt the tests"),
|
|
|
|
Fail(_) => fail2!("test_no_rebuilding failed for some other reason")
|
2013-09-26 18:04:49 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-05 15:40:01 -05:00
|
|
|
#[test]
|
|
|
|
fn test_installed_read_only() {
|
|
|
|
// Install sources from a "remote" (actually a local github repo)
|
|
|
|
// Check that afterward, sources are read-only and installed under build/
|
|
|
|
let temp_pkg_id = git_repo_pkg();
|
|
|
|
let repo = init_git_repo(&temp_pkg_id.path);
|
2013-10-11 08:55:37 -05:00
|
|
|
let repo = repo.path();
|
2013-10-05 15:40:01 -05:00
|
|
|
debug2!("repo = {}", repo.to_str());
|
|
|
|
let repo_subdir = repo.push_many([~"mockgithub.com", ~"catamorphism", ~"test-pkg"]);
|
|
|
|
debug2!("repo_subdir = {}", 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 = (); }");
|
|
|
|
add_git_tag(&repo_subdir, ~"0.1"); // this has the effect of committing the files
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", temp_pkg_id.path.to_str()], repo);
|
2013-10-05 15:40:01 -05:00
|
|
|
|
|
|
|
let ws = repo.push(".rust");
|
|
|
|
// Check that all files exist
|
|
|
|
debug2!("Checking for files in {}", ws.to_str());
|
|
|
|
let exec = target_executable_in_workspace(&temp_pkg_id, &ws);
|
|
|
|
debug2!("exec = {}", exec.to_str());
|
|
|
|
assert!(os::path_exists(&exec));
|
|
|
|
assert!(is_rwx(&exec));
|
|
|
|
let built_lib =
|
|
|
|
built_library_in_workspace(&temp_pkg_id,
|
|
|
|
&ws).expect("test_install_git: built lib should exist");
|
|
|
|
assert!(os::path_exists(&built_lib));
|
|
|
|
assert!(is_rwx(&built_lib));
|
|
|
|
|
|
|
|
// Make sure sources are (a) under "build" and (b) read-only
|
|
|
|
let src1 = target_build_dir(&ws).push_many([~"src", temp_pkg_id.to_str(), ~"main.rs"]);
|
|
|
|
let src2 = target_build_dir(&ws).push_many([~"src", temp_pkg_id.to_str(), ~"lib.rs"]);
|
|
|
|
assert!(os::path_exists(&src1));
|
|
|
|
assert!(os::path_exists(&src2));
|
|
|
|
assert!(is_read_only(&src1));
|
|
|
|
assert!(is_read_only(&src2));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_installed_local_changes() {
|
|
|
|
let temp_pkg_id = git_repo_pkg();
|
|
|
|
let repo = init_git_repo(&temp_pkg_id.path);
|
2013-10-11 08:55:37 -05:00
|
|
|
let repo = repo.path();
|
2013-10-05 15:40:01 -05:00
|
|
|
debug2!("repo = {}", repo.to_str());
|
|
|
|
let repo_subdir = repo.push_many([~"mockgithub.com", ~"catamorphism", ~"test-pkg"]);
|
|
|
|
debug2!("repo_subdir = {}", repo_subdir.to_str());
|
|
|
|
assert!(os::mkdir_recursive(&repo.push_many([".rust", "src"]), U_RWX));
|
|
|
|
|
|
|
|
writeFile(&repo_subdir.push("main.rs"),
|
|
|
|
"fn main() { let _x = (); }");
|
|
|
|
writeFile(&repo_subdir.push("lib.rs"),
|
|
|
|
"pub fn f() { let _x = (); }");
|
|
|
|
add_git_tag(&repo_subdir, ~"0.1"); // this has the effect of committing the files
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"install", temp_pkg_id.path.to_str()], repo);
|
2013-10-05 15:40:01 -05:00
|
|
|
|
|
|
|
|
|
|
|
// We installed the dependency.
|
|
|
|
// Now start a new workspace and clone it into it
|
|
|
|
let hacking_workspace = mk_emptier_workspace("hacking_workspace");
|
2013-10-11 08:55:37 -05:00
|
|
|
let hacking_workspace = hacking_workspace.path();
|
2013-10-05 15:40:01 -05:00
|
|
|
let target_dir = hacking_workspace.push_many([~"src",
|
|
|
|
~"mockgithub.com",
|
|
|
|
~"catamorphism",
|
|
|
|
~"test-pkg-0.1"]);
|
|
|
|
debug2!("---- git clone {} {}", repo_subdir.to_str(), target_dir.to_str());
|
|
|
|
|
|
|
|
let c_res = safe_git_clone(&repo_subdir, &NoVersion, &target_dir);
|
|
|
|
|
|
|
|
match c_res {
|
|
|
|
DirToUse(_) => fail2!("test_installed_local_changes failed"),
|
|
|
|
CheckedOutSources => ()
|
|
|
|
};
|
|
|
|
|
|
|
|
// Make a local change to it
|
|
|
|
writeFile(&target_dir.push("lib.rs"),
|
|
|
|
"pub fn g() { let _x = (); }");
|
|
|
|
|
|
|
|
// Finally, make *another* package that uses it
|
|
|
|
let importer_pkg_id = fake_pkg();
|
2013-10-11 08:55:37 -05:00
|
|
|
let main_subdir = create_local_package_in(&importer_pkg_id, hacking_workspace);
|
2013-10-05 15:40:01 -05:00
|
|
|
writeFile(&main_subdir.push("main.rs"),
|
|
|
|
"extern mod test = \"mockgithub.com/catamorphism/test-pkg\"; \
|
|
|
|
use test::g;
|
|
|
|
fn main() { g(); }");
|
|
|
|
// And make sure we can build it
|
|
|
|
|
2013-10-11 08:55:37 -05:00
|
|
|
command_line_test([~"build", importer_pkg_id.path.to_str()], hacking_workspace);
|
2013-10-05 15:40:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_7402() {
|
|
|
|
let dir = create_local_package(&PkgId::new("foo"));
|
2013-10-11 08:55:37 -05:00
|
|
|
let dest_workspace = TempDir::new("more_rust").expect("test_7402");
|
|
|
|
let dest_workspace = dest_workspace.path();
|
2013-10-05 15:40:01 -05:00
|
|
|
let rust_path = Some(~[(~"RUST_PATH",
|
2013-10-11 08:55:37 -05:00
|
|
|
format!("{}:{}", dest_workspace.to_str(), dir.path().to_str()))]);
|
2013-10-05 15:40:01 -05:00
|
|
|
let cwd = os::getcwd();
|
|
|
|
command_line_test_with_env([~"install", ~"foo"], &cwd, rust_path);
|
2013-10-11 08:55:37 -05:00
|
|
|
assert_executable_exists(dest_workspace, "foo");
|
2013-10-05 15:40:01 -05:00
|
|
|
}
|
|
|
|
|
2013-07-31 15:47:32 -05:00
|
|
|
/// Returns true if p exists and is executable
|
|
|
|
fn is_executable(p: &Path) -> bool {
|
|
|
|
use std::libc::consts::os::posix88::{S_IXUSR};
|
|
|
|
|
|
|
|
match p.get_mode() {
|
|
|
|
None => false,
|
|
|
|
Some(mode) => mode & S_IXUSR as uint == S_IXUSR as uint
|
|
|
|
}
|
|
|
|
}
|