spec/cases/nilify_spec.rb in activecleaner-0.2.0 vs spec/cases/nilify_spec.rb in activecleaner-0.3.0

- old
+ new

@@ -7,15 +7,16 @@ # This is to demonstrate when we want to clean some simple fields and nulify them # class OptimizedPost include ActiveCleaner - attr_accessor :title, :name, :body + attr_accessor :title, :name, :body, :user_generated_content clean :title, nilify: true clean :name, as: :string, nilify: true clean :body, as: :text, nilify: true + clean :user_generated_content, as: :utf8mb3, nilify: true end # # The specs @@ -24,12 +25,12 @@ describe OptimizedPost, "._cleaners" do subject { OptimizedPost._cleaners } - it "has 3 cleaners" do - expect(subject.length).to eq(3) + it "has 4 cleaners" do + expect(subject.length).to eq(4) end it "includes a StringCleaner for #title" do expect(subject[:title].first).to eq(ActiveCleaner::StringCleaner.new(:title, nilify: true)) end @@ -40,10 +41,14 @@ it "includes a TextCleaner for #body" do expect(subject[:body].first).to eq(ActiveCleaner::TextCleaner.new(:body, nilify: true)) end + it "includes a Utf8mb3Cleaner for #user_generated_content" do + expect(subject[:user_generated_content].first).to eq(ActiveCleaner::Utf8mb3Cleaner.new(:user_generated_content, nilify: true)) + end + end # describe context "considering a post" do let(:subject) { OptimizedPost.new } @@ -90,9 +95,25 @@ it "is nulified" do subject.title = " \n \t " subject.valid? expect(subject.title).to be_nil + end + + end # describe + + describe "#user_generated_content, marked as to clean as utf8mb3" do + + it "is untouched when legit" do + subject.user_generated_content = "A good user generated content!" + subject.valid? + expect(subject.user_generated_content).to eq("A good user generated content!") + end + + it "is nulified" do + subject.user_generated_content = "😀" + subject.valid? + expect(subject.user_generated_content).to be_nil end end # describe end # context