Rearranged the project to have src/ and build/ directories
This simplifies keeping everything clean.
This commit is contained in:
45
Rakefile
45
Rakefile
@@ -1,7 +1,8 @@
|
|||||||
DEBUG = true
|
DEBUG = true
|
||||||
|
|
||||||
SOURCES = %w( flexnbd ioutil readwrite serve util parse control remote )
|
SOURCES = FileList['src/*.c']
|
||||||
OBJECTS = SOURCES.map { |s| "#{s}.o" }
|
OBJECTS = SOURCES.pathmap( "%{^src,build}X.o" )
|
||||||
|
|
||||||
LIBS = %w( pthread )
|
LIBS = %w( pthread )
|
||||||
CCFLAGS = %w( -Wall )
|
CCFLAGS = %w( -Wall )
|
||||||
LDFLAGS = []
|
LDFLAGS = []
|
||||||
@@ -15,52 +16,66 @@ if DEBUG
|
|||||||
end
|
end
|
||||||
|
|
||||||
desc "Build flexnbd binary"
|
desc "Build flexnbd binary"
|
||||||
rule 'default' => 'flexnbd'
|
task :flexnbd => 'build/flexnbd'
|
||||||
|
|
||||||
namespace "test" do
|
namespace "test" do
|
||||||
desc "Run all tests"
|
desc "Run all tests"
|
||||||
task 'run' => ["unit", "scenarios"]
|
task 'run' => ["unit", "scenarios"]
|
||||||
|
|
||||||
desc "Build C tests"
|
desc "Build C tests"
|
||||||
task 'build' => TEST_MODULES.map { |n| "tests/check_#{n}" }
|
task 'build' => TEST_MODULES.map { |n| "build/tests/check_#{n}" }
|
||||||
|
|
||||||
desc "Run C tests"
|
desc "Run C tests"
|
||||||
task 'unit' => 'build' do
|
task 'unit' => 'build' do
|
||||||
TEST_MODULES.each do |n|
|
TEST_MODULES.each do |n|
|
||||||
ENV['EF_DISABLE_BANNER'] = '1'
|
ENV['EF_DISABLE_BANNER'] = '1'
|
||||||
sh "./tests/check_#{n}"
|
sh "build/tests/check_#{n}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Run NBD test scenarios"
|
desc "Run NBD test scenarios"
|
||||||
task 'scenarios' => 'flexnbd' do
|
task 'scenarios' => 'flexnbd' do
|
||||||
sh "cd tests; ruby nbd_scenarios"
|
sh "cd tests; ruby nbd_scenarios"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
def gcc_link(target, objects)
|
def gcc_link(target, objects)
|
||||||
|
FileUtils.mkdir_p File.dirname( target )
|
||||||
|
|
||||||
sh "gcc #{LDFLAGS.join(' ')} "+
|
sh "gcc #{LDFLAGS.join(' ')} "+
|
||||||
LIBS.map { |l| "-l#{l}" }.join(" ")+
|
LIBS.map { |l| "-l#{l}" }.join(" ")+
|
||||||
|
" -I src" +
|
||||||
" -o #{target} "+
|
" -o #{target} "+
|
||||||
objects.join(" ")
|
objects.join(" ")
|
||||||
end
|
end
|
||||||
|
|
||||||
rule 'flexnbd' => OBJECTS do |t|
|
rule 'build/flexnbd' => OBJECTS do |t|
|
||||||
gcc_link(t.name, t.sources)
|
gcc_link(t.name, t.sources)
|
||||||
end
|
end
|
||||||
|
|
||||||
rule(/tests\/check_[a-z]+$/ => [ proc { |target| [target+".o", "util.o"] } ]) do |t|
|
TEST_MODULES.each do |m|
|
||||||
gcc_link(t.name, t.sources + [LIBCHECK])
|
deps = ["tests/check_#{m}.c", "build/util.o"]
|
||||||
|
maybe_obj_name = "build/#{m}.o"
|
||||||
|
|
||||||
|
deps << maybe_obj_name if OBJECTS.include?( maybe_obj_name )
|
||||||
|
|
||||||
|
file "build/tests/check_#{m}" => deps do |t|
|
||||||
|
gcc_link(t.name, deps + [LIBCHECK])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
rule '.o' => '.c' do |t|
|
|
||||||
sh "gcc -I. -c #{CCFLAGS.join(' ')} -o #{t.name} #{t.source} "
|
OBJECTS.zip( SOURCES ).each do |o,c|
|
||||||
|
file o => c do |t|
|
||||||
|
FileUtils.mkdir_p File.dirname( o )
|
||||||
|
sh "gcc -Isrc -c #{CCFLAGS.join(' ')} -o #{o} #{c} "
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Remove all build targets, binaries and temporary files"
|
desc "Remove all build targets, binaries and temporary files"
|
||||||
rule 'clean' do
|
rule 'clean' do
|
||||||
sh "rm -f *~ flexnbd " + (
|
sh "rm -rf *~ build " + (
|
||||||
OBJECTS +
|
|
||||||
TEST_MODULES.map { |n| ["tests/check_#{n}", "tests/check_#{n}.o"] }.flatten
|
TEST_MODULES.map { |n| ["tests/check_#{n}", "tests/check_#{n}.o"] }.flatten
|
||||||
).
|
).
|
||||||
join(" ")
|
join(" ")
|
||||||
|
@@ -13,39 +13,39 @@ class NBDScenarios < Test::Unit::TestCase
|
|||||||
@available_ports = [*40000..41000] - listening_ports
|
@available_ports = [*40000..41000] - listening_ports
|
||||||
@port1 = @available_ports.shift
|
@port1 = @available_ports.shift
|
||||||
@port2 = @available_ports.shift
|
@port2 = @available_ports.shift
|
||||||
@nbd1 = FlexNBD.new("../flexnbd", @ip, @port1)
|
@nbd1 = FlexNBD.new("../build/flexnbd", @ip, @port1)
|
||||||
end
|
end
|
||||||
|
|
||||||
def teardown
|
def teardown
|
||||||
@nbd1.kill rescue nil
|
@nbd1.kill rescue nil
|
||||||
[@filename1, @filename2].each do |f|
|
[@filename1, @filename2].each do |f|
|
||||||
File.unlink(f) if File.exists?(f)
|
File.unlink(f) if File.exists?(f)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_read1
|
def test_read1
|
||||||
writefile1("f"*64)
|
writefile1("f"*64)
|
||||||
serve1
|
serve1
|
||||||
|
|
||||||
[0, 12, 63].each do |num|
|
[0, 12, 63].each do |num|
|
||||||
|
|
||||||
assert_equal(
|
assert_equal(
|
||||||
@nbd1.read(num*@blocksize, @blocksize),
|
@nbd1.read(num*@blocksize, @blocksize),
|
||||||
@file1.read(num*@blocksize, @blocksize)
|
@file1.read(num*@blocksize, @blocksize)
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
[124, 1200, 10028, 25488].each do |num|
|
[124, 1200, 10028, 25488].each do |num|
|
||||||
assert_equal(@nbd1.read(num, 4), @file1.read(num, 4))
|
assert_equal(@nbd1.read(num, 4), @file1.read(num, 4))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Check that we're not
|
# Check that we're not
|
||||||
#
|
#
|
||||||
def test_writeread1
|
def test_writeread1
|
||||||
writefile1("0"*64)
|
writefile1("0"*64)
|
||||||
serve1
|
serve1
|
||||||
|
|
||||||
[0, 12, 63].each do |num|
|
[0, 12, 63].each do |num|
|
||||||
data = "X"*@blocksize
|
data = "X"*@blocksize
|
||||||
@nbd1.write(num*@blocksize, data)
|
@nbd1.write(num*@blocksize, data)
|
||||||
@@ -53,14 +53,14 @@ class NBDScenarios < Test::Unit::TestCase
|
|||||||
assert_equal(data, @nbd1.read(num*@blocksize, data.size))
|
assert_equal(data, @nbd1.read(num*@blocksize, data.size))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Check that we're not overstepping or understepping where our writes end
|
# Check that we're not overstepping or understepping where our writes end
|
||||||
# up.
|
# up.
|
||||||
#
|
#
|
||||||
def test_writeread2
|
def test_writeread2
|
||||||
writefile1("0"*1024)
|
writefile1("0"*1024)
|
||||||
serve1
|
serve1
|
||||||
|
|
||||||
d0 = "\0"*@blocksize
|
d0 = "\0"*@blocksize
|
||||||
d1 = "X"*@blocksize
|
d1 = "X"*@blocksize
|
||||||
(0..63).each do |num|
|
(0..63).each do |num|
|
||||||
@@ -70,16 +70,16 @@ class NBDScenarios < Test::Unit::TestCase
|
|||||||
assert_equal(d0, @nbd1.read(((2*num)+1)*@blocksize, d0.size))
|
assert_equal(d0, @nbd1.read(((2*num)+1)*@blocksize, d0.size))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
def serve1(*acl)
|
def serve1(*acl)
|
||||||
@nbd1.serve(@ip, @port1, @filename1, *acl)
|
@nbd1.serve(@ip, @port1, @filename1, *acl)
|
||||||
end
|
end
|
||||||
|
|
||||||
def writefile1(data)
|
def writefile1(data)
|
||||||
@file1 = TestFileWriter.new(@filename1, @blocksize).write(data)
|
@file1 = TestFileWriter.new(@filename1, @blocksize).write(data)
|
||||||
end
|
end
|
||||||
|
|
||||||
def listening_ports
|
def listening_ports
|
||||||
`netstat -ltn`.
|
`netstat -ltn`.
|
||||||
split("\n").
|
split("\n").
|
||||||
|
Reference in New Issue
Block a user