cloudfoundry/membrane

View on GitHub
lib/membrane/schemas/regexp.rb

Summary

Maintainability
A
20 mins
Test Coverage
require "membrane/errors"
require "membrane/schemas/base"

module Membrane
  module Schema
  end
end

class Membrane::Schemas::Regexp < Membrane::Schemas::Base
  attr_reader :regexp

  def initialize(regexp)
    @regexp = regexp
  end

  def validate(object)
    StringValidator.new(object).validate
    MatchValidator.new(@regexp, object).validate

    nil
  end

  class StringValidator

    def initialize(object)
      @object = object
    end

    def validate
      fail!(@object) if !@object.kind_of?(String)
    end

    private

    def fail!(object)
      emsg = "Expected instance of String, given instance of #{object.class}"
      raise Membrane::SchemaValidationError.new(emsg)
    end

  end

  class MatchValidator

    def initialize(regexp, object)
      @regexp = regexp
      @object = object
    end

    def validate
      fail!(@regexp, @object) if !@regexp.match(@object)
    end

    private

    def fail!(regexp, object)
      emsg = "Value #{object} doesn't match regexp #{regexp.inspect}"
      raise Membrane::SchemaValidationError.new(emsg)
    end
  end
end