mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-10 08:16:15 +02:00
* Obsolete.
This commit is contained in:
parent
a29c8ac51c
commit
795d9f8b08
1 changed files with 0 additions and 162 deletions
|
@ -1,162 +0,0 @@
|
|||
#include <iostream>
|
||||
|
||||
#include <sys/stat.h>
|
||||
#include <sys/types.h>
|
||||
|
||||
#include "hash.hh"
|
||||
#include "archive.hh"
|
||||
#include "util.hh"
|
||||
#include "normalise.hh"
|
||||
#include "globals.hh"
|
||||
|
||||
|
||||
void realise(Path nePath)
|
||||
{
|
||||
Nest nest(lvlDebug, format("TEST: realising `%1%'") % nePath);
|
||||
realiseClosure(normaliseNixExpr(nePath));
|
||||
}
|
||||
|
||||
|
||||
struct MySink : DumpSink
|
||||
{
|
||||
virtual void operator () (const unsigned char * data, unsigned int len)
|
||||
{
|
||||
/* Don't use cout, it's slow as hell! */
|
||||
writeFull(STDOUT_FILENO, data, len);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
struct MySource : RestoreSource
|
||||
{
|
||||
virtual void operator () (unsigned char * data, unsigned int len)
|
||||
{
|
||||
readFull(STDIN_FILENO, data, len);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
void runTests()
|
||||
{
|
||||
verbosity = (Verbosity) 100;
|
||||
|
||||
/* Hashing. */
|
||||
string s = "0b0ffd0538622bfe20b92c4aa57254d9";
|
||||
Hash h = parseHash(s);
|
||||
if ((string) h != s) abort();
|
||||
|
||||
try {
|
||||
h = parseHash("blah blah");
|
||||
abort();
|
||||
} catch (Error err) { };
|
||||
|
||||
try {
|
||||
h = parseHash("0b0ffd0538622bfe20b92c4aa57254d99");
|
||||
abort();
|
||||
} catch (Error err) { };
|
||||
|
||||
/* Path canonicalisation. */
|
||||
cout << canonPath("/./../././//") << endl;
|
||||
cout << canonPath("/foo/bar") << endl;
|
||||
cout << canonPath("///foo/////bar//") << endl;
|
||||
cout << canonPath("/././/foo/////bar//.") << endl;
|
||||
cout << canonPath("/foo////bar//..///x/") << endl;
|
||||
cout << canonPath("/foo////bar//..//..//x/y/../z/") << endl;
|
||||
cout << canonPath("/foo/bar/../../../..///") << endl;
|
||||
|
||||
/* Dumping. */
|
||||
|
||||
#if 0
|
||||
MySink sink;
|
||||
dumpPath("scratch", sink);
|
||||
cout << (string) hashPath("scratch") << endl;
|
||||
#endif
|
||||
|
||||
/* Restoring. */
|
||||
#if 0
|
||||
MySource source;
|
||||
restorePath("outdir", source);
|
||||
cout << (string) hashPath("outdir") << endl;
|
||||
return;
|
||||
#endif
|
||||
|
||||
/* Set up the test environment. */
|
||||
|
||||
mkdir("scratch", 0777);
|
||||
mkdir("scratch/db", 0777);
|
||||
|
||||
string testDir = absPath("scratch");
|
||||
cout << testDir << endl;
|
||||
|
||||
nixStore = testDir;
|
||||
nixLogDir = testDir;
|
||||
nixDBPath = testDir + "/db";
|
||||
|
||||
openDB();
|
||||
initDB();
|
||||
|
||||
/* Expression evaluation. */
|
||||
|
||||
Path builder1fn;
|
||||
builder1fn = addToStore("./test-builder-1.sh");
|
||||
|
||||
ATerm fs1 = ATmake(
|
||||
"Closure([<str>], [(<str>, [])])",
|
||||
builder1fn.c_str(),
|
||||
builder1fn.c_str());
|
||||
Path fs1ne = writeTerm(fs1, "-c");
|
||||
|
||||
realise(fs1ne);
|
||||
realise(fs1ne);
|
||||
|
||||
string out1h = hashString("foo"); /* !!! bad */
|
||||
Path out1fn = nixStore + "/" + (string) out1h + "-hello.txt";
|
||||
ATerm fs3 = ATmake(
|
||||
"Derive([<str>], [<str>], <str>, <str>, [], [(\"out\", <str>)])",
|
||||
out1fn.c_str(),
|
||||
fs1ne.c_str(),
|
||||
thisSystem.c_str(),
|
||||
builder1fn.c_str(),
|
||||
out1fn.c_str());
|
||||
debug(printTerm(fs3));
|
||||
Path fs3ne = writeTerm(fs3, "-d");
|
||||
|
||||
realise(fs3ne);
|
||||
realise(fs3ne);
|
||||
|
||||
|
||||
Path builder4fn = addToStore("./test-builder-2.sh");
|
||||
|
||||
ATerm fs4 = ATmake(
|
||||
"Closure([<str>], [(<str>, [])])",
|
||||
builder4fn.c_str(),
|
||||
builder4fn.c_str());
|
||||
Path fs4ne = writeTerm(fs4, "-c");
|
||||
|
||||
realise(fs4ne);
|
||||
|
||||
string out5h = hashString("bar"); /* !!! bad */
|
||||
Path out5fn = nixStore + "/" + (string) out5h + "-hello2";
|
||||
ATerm fs5 = ATmake(
|
||||
"Derive([<str>], [<str>], <str>, <str>, [], [(\"out\", <str>), (\"builder\", <str>)])",
|
||||
out5fn.c_str(),
|
||||
fs4ne.c_str(),
|
||||
thisSystem.c_str(),
|
||||
builder4fn.c_str(),
|
||||
out5fn.c_str(),
|
||||
builder4fn.c_str());
|
||||
debug(printTerm(fs5));
|
||||
Path fs5ne = writeTerm(fs5, "-d");
|
||||
|
||||
realise(fs5ne);
|
||||
realise(fs5ne);
|
||||
}
|
||||
|
||||
|
||||
void run(Strings args)
|
||||
{
|
||||
runTests();
|
||||
}
|
||||
|
||||
|
||||
string programId = "test";
|
Loading…
Reference in a new issue