(#2) unstub is_valid_domain_name

This commit is contained in:
Ken Barber 2011-07-29 20:08:31 +01:00
parent 62520a2df0
commit 56a402e654
2 changed files with 38 additions and 5 deletions

View file

@ -12,6 +12,14 @@ module Puppet::Parser::Functions
"given #{arguments.size} for 1") "given #{arguments.size} for 1")
end end
domain = arguments[0]
if domain =~ /^(([a-zA-Z0-9][a-zA-Z0-9\-]*[a-zA-Z0-9])\.)*([A-Za-z0-9][A-Za-z0-9\-]*[A-Za-z0-9])\.?$/ then
return true
else
return false
end
end end
end end

View file

@ -19,13 +19,38 @@ describe "the is_valid_domain_name function" do
end end
it "should return true if a valid domain name" do it "should return true if a valid domain name" do
result = @scope.function_is_valid_domain_name("foo.bar.com") result = @scope.function_is_valid_domain_name(["foo.bar.com"])
result.should(eq(true)) result.should(be_true)
end end
it "should return false if not a valid domain name" do it "should allow domain parts to start with numbers" do
result = @scope.function_is_valid_domain_name("not valid") result = @scope.function_is_valid_domain_name(["3foo.2bar.com"])
result.should(eq(false)) result.should(be_true)
end
it "should allow domain to end with a dot" do
result = @scope.function_is_valid_domain_name(["3foo.2bar.com."])
result.should(be_true)
end
it "should allow a single part domain" do
result = @scope.function_is_valid_domain_name(["orange"])
result.should(be_true)
end
it "should return false if domain parts start with hyphens" do
result = @scope.function_is_valid_domain_name(["-3foo.2bar.com"])
result.should(be_false)
end
it "should return true if domain contains hyphens" do
result = @scope.function_is_valid_domain_name(["3foo-bar.2bar-fuzz.com"])
result.should(be_true)
end
it "should return false if domain name contains spaces" do
result = @scope.function_is_valid_domain_name(["not valid"])
result.should(be_false)
end end
end end