Namespace languages controller to admin

This commit is contained in:
maddiebaka
2023-10-25 16:25:29 -04:00
parent 206c4da31f
commit c2891a66f8
17 changed files with 43 additions and 41 deletions

View File

@@ -4,59 +4,59 @@ RSpec.describe "Languages", type: :request do
describe "GET :index" do
it "returns http success" do
get "/languages/"
get "/admin/languages/"
expect(response).to have_http_status(:success)
end
it "lists all languages" do
language = FactoryBot.create(:language)
get "/languages/"
get "/admin/languages/"
expect(response.body).to include(language.name)
end
it "has a new-language link" do
get "/languages/"
expect(response.body).to have_selector(%(a[href="#{new_language_path}"]))
get "/admin/languages/"
expect(response.body).to have_selector(%(a[href="#{new_admin_language_path}"]))
end
it "has an edit button" do
language = FactoryBot.create(:language)
get "/languages/"
get "/admin/languages/"
expect(response.body).to have_link("Edit")
end
it "has a delete button" do
language = FactoryBot.create(:language)
get "/languages/"
get "/admin/languages/"
expect(response.body).to have_link("Delete")
end
end
describe "GET :new" do
it "returns http success" do
get "/languages/new"
get "/admin/languages/new"
expect(response).to have_http_status(:success)
end
it "has a form for a new language" do
get "/languages/new"
get "/admin/languages/new"
expect(response.body).to have_selector(%(input[name="language[name]"]))
end
end
describe "POST :create" do
it "redirect to languages_path on success" do
post "/languages", params: { language: { name: "Test Name" } }
expect(response).to redirect_to(languages_path)
it "redirect to admin_languages_path on success" do
post "/admin/languages", params: { language: { name: "Test Name" } }
expect(response).to redirect_to(admin_languages_path)
end
it "creates a new language" do
post "/languages", params: { language: { name: "Test Name" } }
post "/admin/languages", params: { language: { name: "Test Name" } }
expect(Language.count).to eq(1)
end
it "requires a name for a new language" do
post "/languages", params: { language: { name: nil } }
post "/admin/languages", params: { language: { name: nil } }
expect(response).to have_http_status(:unprocessable_entity)
end
end
@@ -64,7 +64,7 @@ RSpec.describe "Languages", type: :request do
describe "GET :edit" do
before :each do
@language = FactoryBot.create(:language)
get "/languages/#{@language.id}/edit"
get "/admin/languages/#{@language.id}/edit"
end
it "returns http success" do
@@ -83,13 +83,13 @@ RSpec.describe "Languages", type: :request do
end
it "updates a language" do
patch "/languages/#{@language.id}", params: @params
expect(response).to redirect_to(languages_path)
patch "/admin/languages/#{@language.id}", params: @params
expect(response).to redirect_to(admin_languages_path)
end
it "requires params to update a language" do
@params = { language: { name: nil, invalid: "oh no" } }
patch "/languages/#{@language.id}", params: @params
patch "/admin/languages/#{@language.id}", params: @params
expect(response).to have_http_status(:unprocessable_entity)
end
@@ -99,7 +99,7 @@ RSpec.describe "Languages", type: :request do
it "deletes a language" do
language = FactoryBot.create(:language)
language2 = FactoryBot.create(:language)
delete "/languages/#{language.id}"
delete "/admin/languages/#{language.id}"
expect(Language.all).to eq([language2])
end
end

View File

@@ -30,7 +30,7 @@ RSpec.describe "Root path", type: :request do
it "should have the 'Languages' link" do
sign_in FactoryBot.create(:user)
get root_path
expect(response.body).to have_selector(%(a[href="#{languages_path}"]))
expect(response.body).to have_selector(%(a[href="#{admin_languages_path}"]))
end
it "should welcome user by username" do