lib/buildr/core/checks.rb in assaf-buildr-1.3.3 vs lib/buildr/core/checks.rb in assaf-buildr-1.3.4
- old
+ new
@@ -13,14 +13,11 @@
# License for the specific language governing permissions and limitations under
# the License.
require 'buildr/core/project'
-require 'buildr/packaging/zip'
-#require 'test/unit'
-require 'spec/matchers'
-require 'spec/expectations'
+autoload :Spec, 'spec'
module Buildr
# Methods added to Project to allow checking the build.
module Checks
@@ -116,12 +113,12 @@
# - All instance methods defined in context, so we can pass method calls to the context.
# - it() method to return subject, description() method to return description.
# - All matchers defined by Buildr and RSpec.
klass = Class.new
klass.instance_eval do
- context.class.instance_methods(false).each do |method|
- define_method(method) { |*args| context.send(method, *args) }
+ context.class.instance_methods.each do |method|
+ define_method(method) { |*args| context.send(method, *args) } unless instance_methods.include?(method)
end
define_method(:it) { subject }
define_method(:description) { description }
include Spec::Matchers
include Matchers
@@ -247,134 +244,9 @@
all? { |pattern| contents =~ pattern }
end
end
end
-end
-
-
-module Zip #:nodoc:
- class ZipEntry
-
- # :call-seq:
- # exist() => boolean
- #
- # Returns true if this entry exists.
- def exist?()
- Zip::ZipFile.open(zipfile) { |zip| zip.file.exist?(@name) }
- end
-
- # :call-seq:
- # empty?() => boolean
- #
- # Returns true if this entry is empty.
- def empty?()
- Zip::ZipFile.open(zipfile) { |zip| zip.file.read(@name) }.empty?
- end
-
- # :call-seq:
- # contain(patterns*) => boolean
- #
- # Returns true if this ZIP file entry matches against all the arguments. An argument may be
- # a string or regular expression.
- def contain?(*patterns)
- content = Zip::ZipFile.open(zipfile) { |zip| zip.file.read(@name) }
- patterns.map { |pattern| Regexp === pattern ? pattern : Regexp.new(Regexp.escape(pattern.to_s)) }.
- all? { |pattern| content =~ pattern }
- end
-
- end
-end
-
-
-class Buildr::ArchiveTask
-
- class Path #:nodoc:
-
- # :call-seq:
- # exist() => boolean
- #
- # Returns true if this path exists. This only works if the path has any entries in it,
- # so exist on path happens to be the opposite of empty.
- def exist?()
- !entries.empty?
- end
-
- # :call-seq:
- # empty?() => boolean
- #
- # Returns true if this path is empty (has no other entries inside).
- def empty?()
- entries.all? { |entry| entry.empty? }
- end
-
- # :call-seq:
- # contain(file*) => boolean
- #
- # Returns true if this ZIP file path contains all the specified files. You can use relative
- # file names and glob patterns (using *, **, etc).
- def contain?(*files)
- files.all? { |file| entries.detect { |entry| File.fnmatch(file, entry.to_s, File::FNM_PATHNAME) } }
- end
-
- # :call-seq:
- # entry(name) => ZipEntry
- #
- # Returns a ZIP file entry. You can use this to check if the entry exists and its contents,
- # for example:
- # package(:jar).path("META-INF").entry("LICENSE").should contain(/Apache Software License/)
- def entry(name)
- root.entry("#{@path}#{name}")
- end
-
- protected
-
- def entries() #:nodoc:
- return root.entries unless @path
- @entries ||= root.entries.inject([]) { |selected, entry|
- selected << entry.name.sub(@path, "") if entry.name.index(@path) == 0
- selected
- }
- end
-
- end
-
- # :call-seq:
- # empty?() => boolean
- #
- # Returns true if this ZIP file is empty (has no other entries inside).
- def empty?()
- path("").empty
- end
-
- # :call-seq:
- # contain(file*) => boolean
- #
- # Returns true if this ZIP file contains all the specified files. You can use absolute
- # file names and glob patterns (using *, **, etc).
- def contain?(*files)
- path("").contain?(*files)
- end
-
-end
-
-
-class Buildr::ZipTask #:nodoc:
-
- # :call-seq:
- # entry(name) => Entry
- #
- # Returns a ZIP file entry. You can use this to check if the entry exists and its contents,
- # for example:
- # package(:jar).entry("META-INF/LICENSE").should contain(/Apache Software License/)
- def entry(entry_name)
- ::Zip::ZipEntry.new(name, entry_name)
- end
-
- def entries() #:nodoc:
- @entries ||= Zip::ZipFile.open(name) { |zip| zip.entries }
- end
-
end
class Buildr::Project
include Buildr::Checks