Rearranged the project to have src/ and build/ directories

This simplifies keeping everything clean.
This commit is contained in:
Alex Young
2012-05-30 09:51:20 +01:00
parent 21ccd17ea5
commit 7832958522
19 changed files with 48 additions and 31 deletions

View File

@@ -1,3 +1,5 @@
.o$ .o$
~$ ~$
^flexnbd$ ^flexnbd$
^build/
^pkg/

View File

@@ -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(" ")

View File

View File

View File

@@ -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").