2016-04-01 4 views
2

Я бегу RSpec для API, в частности, для создания сообщения (я также работаю на: обновление и:. Уничтожить, но те два отлично работает у меня возникли проблемы с: создать)Рельсы, как исправить искаженный запрос (код ошибки 400)?

Вот мои RSpec:

describe "POST create" do 
    before { post :create, topic_id: my_topic.id, post: {title: @new_post.title, body: @new_post.body} } 

    it "returns http success" do 
    expect(response).to have_http_status(:success) 
    end 

    it "returns json content type" do 
    expect(response.content_type).to eq 'application/json' 
    end 

    it "creates a topic with the correct attributes" do 
    hashed_json = JSON.parse(response.body) 
    expect(hashed_json["title"]).to eq(@new_post.title) 
    expect(hashed_json["body"]).to eq(@new_post.body) 
    end 
end 

А вот мой создать

def create 
    post = Post.new(post_params) 

    if post.valid? 
     post.save! 
     render json: post.to_json, status: 201 
    else 
     render json: {error: "Post is invalid", status: 400}, status: 400 
    end 
    end 

Вот код ошибки, что я получаю:

.........F.F.... 

Failures: 

    1) Api::V1::PostsController authenticated and authorized users POST create returns http success 
    Failure/Error: expect(response).to have_http_status(:success) 
     expected the response to have a success status code (2xx) but it was 400 
    # ./spec/api/v1/controllers/posts_controller_spec.rb:78:in `block (4 levels) in <top (required)>' 

Я действительно не уверен, что не так с кодом. Маршруты работают нормально. Как я могу пройти тесты?

+1

Очевидно, что 'post.valid?' Является 'false'. Узнайте, почему! Возможно, добавив 'p post.errors' в' else' часть вашего метода контроллера. – spickermann

+0

Вы можете проверить log/test.log, чтобы увидеть ошибку. В качестве альтернативы вы можете связать свой вопрос с другим, чтобы помочь вам отлаживать. – Shishir

+0

@Shishir Вы не разделяете, как я могу связать вопрос для отладки справки? Благодаря! – Iggy

ответ

1

Для лучшего решения tha @spickermann предложите изменить post на @post в вашем действии #create и добавьте нижеприведенный код к вашим спецификациям и работайте оттуда. Бьюсь об заклад, вы должны сделать что-то вроде @post.user = current_user в своем контроллере.

it "@post is valid and have no errors" do 
    expect(assigns[:post]).to be_valid 
    expect(assigns[:post].errors).to be_empty 
end 
Смежные вопросы