require 'rails_helper'

# This spec was generated by rspec-rails when you ran the scaffold generator.
# It demonstrates how one might use RSpec to test the controller code that
# was generated by Rails when you ran the scaffold generator.
#
# It assumes that the implementation code is generated by the rails scaffold
# generator. If you are using any extension libraries to generate different
# controller code, this generated spec may or may not pass.
#
# It only uses APIs available in rails and/or rspec-rails. There are a number
# of tools you can use to make these specs even more expressive, but we're
# sticking to rails and rspec-rails APIs to keep things simple and stable.

RSpec.describe "/cms/pages", type: :request do
  
  # Cms::Page. As you add validations to Cms::Page, be sure to
  # adjust the attributes here as well.
  let(:valid_attributes) {
    skip("Add a hash of attributes valid for your model")
  }

  let(:invalid_attributes) {
    skip("Add a hash of attributes invalid for your model")
  }

  describe "GET /index" do
    it "renders a successful response" do
      Cms::Page.create! valid_attributes
      get cms_pages_url
      expect(response).to be_successful
    end
  end

  describe "GET /show" do
    it "renders a successful response" do
      page = Cms::Page.create! valid_attributes
      get cms_page_url(cms_page)
      expect(response).to be_successful
    end
  end

  describe "GET /new" do
    it "renders a successful response" do
      get new_cms_page_url
      expect(response).to be_successful
    end
  end

  describe "GET /edit" do
    it "render a successful response" do
      page = Cms::Page.create! valid_attributes
      get edit_cms_page_url(cms_page)
      expect(response).to be_successful
    end
  end

  describe "POST /create" do
    context "with valid parameters" do
      it "creates a new Cms::Page" do
        expect {
          post cms_pages_url, params: { cms_page: valid_attributes }
        }.to change(Cms::Page, :count).by(1)
      end

      it "redirects to the created cms_page" do
        post cms_pages_url, params: { cms_page: valid_attributes }
        expect(response).to redirect_to(cms_page_url(@cms_page))
      end
    end

    context "with invalid parameters" do
      it "does not create a new Cms::Page" do
        expect {
          post cms_pages_url, params: { cms_page: invalid_attributes }
        }.to change(Cms::Page, :count).by(0)
      end

      it "renders a successful response (i.e. to display the 'new' template)" do
        post cms_pages_url, params: { cms_page: invalid_attributes }
        expect(response).to be_successful
      end
    end
  end

  describe "PATCH /update" do
    context "with valid parameters" do
      let(:new_attributes) {
        skip("Add a hash of attributes valid for your model")
      }

      it "updates the requested cms_page" do
        page = Cms::Page.create! valid_attributes
        patch cms_page_url(cms_page), params: { cms_page: new_attributes }
        page.reload
        skip("Add assertions for updated state")
      end

      it "redirects to the cms_page" do
        page = Cms::Page.create! valid_attributes
        patch cms_page_url(cms_page), params: { cms_page: new_attributes }
        page.reload
        expect(response).to redirect_to(cms_page_url(page))
      end
    end

    context "with invalid parameters" do
      it "renders a successful response (i.e. to display the 'edit' template)" do
        page = Cms::Page.create! valid_attributes
        patch cms_page_url(cms_page), params: { cms_page: invalid_attributes }
        expect(response).to be_successful
      end
    end
  end

  describe "DELETE /destroy" do
    it "destroys the requested cms_page" do
      page = Cms::Page.create! valid_attributes
      expect {
        delete cms_page_url(cms_page)
      }.to change(Cms::Page, :count).by(-1)
    end

    it "redirects to the cms_pages list" do
      page = Cms::Page.create! valid_attributes
      delete cms_page_url(cms_page)
      expect(response).to redirect_to(cms_pages_url)
    end
  end
end