mirror of
https://github.com/NixOS/mobile-nixos.git
synced 2025-01-05 19:03:21 +03:00
33c2ecdeae
Using an override is more likely to pass the smell test than a magic environment variable.
145 lines
3.4 KiB
Ruby
Executable File
145 lines
3.4 KiB
Ruby
Executable File
#!/usr/bin/env nix-shell
|
|
# All dependencies `verify` will need too.
|
|
#!nix-shell --pure -p nix -p ruby -p file -i ruby
|
|
|
|
require "tmpdir"
|
|
require "open3"
|
|
require "json"
|
|
# require "fileutils"
|
|
|
|
prefix = File.join(__dir__, "tests")
|
|
NIX_PATH = "nixpkgs-overlays=#{__dir__}/lib/tests/test-overlay.nix:nixpkgs=channel:nixos-19.03"
|
|
|
|
# Default directives for the test.
|
|
DEFAULT_DIRECTIVES = {
|
|
# Default is to succeed.
|
|
status: 0,
|
|
|
|
# Nothing to grep for in particular.
|
|
# (Caution! Successes are likely not to have logs!)
|
|
grep: nil,
|
|
}
|
|
|
|
Env = {
|
|
"NIX_PATH" => NIX_PATH,
|
|
}
|
|
|
|
tests =
|
|
if ARGV.count > 0 then
|
|
ARGV
|
|
else
|
|
# Assumes all nix files in `./tests` are tests to `nix-build`.
|
|
Dir.glob(File.join(prefix, "**/*.nix"))
|
|
end
|
|
|
|
tests.sort!
|
|
|
|
$exit = 0
|
|
$failed_tests = []
|
|
|
|
puts ""
|
|
puts "Tests"
|
|
puts "====="
|
|
puts ""
|
|
|
|
tests.each_with_index do |file, index|
|
|
short_name = file.sub("#{prefix}/", "")
|
|
print "Running test #{(index+1).to_s.rjust(tests.length.to_s.length)}/#{tests.length} '#{short_name}' "
|
|
|
|
failures = []
|
|
|
|
# Reads the first line of the file. It may hold a json snippet
|
|
# configuring the expected test results.
|
|
directives = File.read(file).split("\n").first || ""
|
|
directives = DEFAULT_DIRECTIVES.merge(
|
|
if directives.match(/^\s*#\s*expect:/i) then
|
|
# Parse...
|
|
JSON.parse(
|
|
# Everything after the first colon as json
|
|
directives.split(":", 2).last,
|
|
symbolize_names: true,
|
|
)
|
|
else
|
|
{}
|
|
end
|
|
)
|
|
|
|
# The result symlink is in a temp directory...
|
|
Dir.mktmpdir("image-builder-test") do |dir|
|
|
result = File.join(dir, "result")
|
|
|
|
# TODO : figure out how to keep stdout/stderr synced but logged separately.
|
|
log, status = Open3.capture2e(Env, "nix-build", "--show-trace", "--out-link", result, file)
|
|
|
|
unless status.exitstatus == directives[:status]
|
|
failures << "Build exited with status #{status.exitstatus} expected #{directives[:status]}."
|
|
end
|
|
|
|
if directives[:grep] then
|
|
unless log.match(directives[:grep])
|
|
failures << "Output log did not match `#{directives[:grep]}`."
|
|
end
|
|
end
|
|
|
|
# Do we test further with the test scripts?
|
|
if failures.length == 0 and status.success? then
|
|
script = file.sub(/\.nix$/, ".rb")
|
|
if File.exists?(script) then
|
|
log, status = Open3.capture2e(Env, File.join(__dir__, "lib/tests/verify.rb"), script, result)
|
|
end
|
|
|
|
unless status.exitstatus == 0
|
|
failures << "Verification exited with status #{status.exitstatus} expected 0."
|
|
end
|
|
|
|
store_path = File.readlink(result)
|
|
end
|
|
|
|
if failures.length == 0 then
|
|
puts "[Success] (#{store_path || "no output"}) "
|
|
else
|
|
$exit = 1
|
|
$failed_tests << file
|
|
puts "[Failed] (#{store_path || "no output"}) "
|
|
puts ""
|
|
puts "Failures:"
|
|
failures.each do |failure|
|
|
puts " - #{failure}"
|
|
end
|
|
puts ""
|
|
puts "Directives:"
|
|
puts ""
|
|
puts "```"
|
|
puts "#{directives.inspect}"
|
|
puts "```"
|
|
|
|
puts ""
|
|
puts "Output from the test:"
|
|
puts ""
|
|
puts "````"
|
|
puts "#{log}"
|
|
puts "````"
|
|
end
|
|
end
|
|
end
|
|
|
|
puts ""
|
|
puts "* * *"
|
|
puts ""
|
|
puts "Test summary"
|
|
puts "============"
|
|
puts ""
|
|
|
|
puts "#{tests.length - $failed_tests.length}/#{tests.length} tests successful."
|
|
|
|
if $failed_tests.length > 0 then
|
|
puts ""
|
|
puts "Failed tests:\n"
|
|
$failed_tests.each do |filename|
|
|
puts " - #{filename.sub(/^#{__dir__}/, ".")}"
|
|
end
|
|
puts ""
|
|
end
|
|
|
|
exit $exit
|