5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2024-11-28 18:36:23 +00:00
panel/test/controllers/api/v1/posts_controller_test.rb

148 lines
4.1 KiB
Ruby

# frozen_string_literal: true
require 'test_helper'
module Api
module V1
class PostsControllerTest < ActionDispatch::IntegrationTest
setup do
@rol = create :rol
@site = @rol.site
@usuarie = @rol.usuarie
@site.update_attribute :colaboracion_anonima, true
end
teardown do
@site.destroy
end
test 'no se pueden enviar sin cookie' do
post v1_site_posts_url(@site.hostname, layout: :post, **@host), params: {
post: {
title: SecureRandom.hex,
description: SecureRandom.hex
}
}
posts = @site.posts.size
@site = Site.find(@site.id)
assert_equal posts, @site.posts.size
assert_response :precondition_required
assert_equal 'expired_or_invalid_cookie', response.body
end
test 'no se pueden enviar a sitios que no existen' do
site = SecureRandom.hex
get v1_site_invitades_cookie_url(site_id: site, **@host)
assert_not cookies[site]
get v1_site_invitades_cookie_url(@site.hostname, **@host)
assert cookies[@site.name]
post v1_site_posts_url(site_id: site, layout: :post, **@host),
headers: { cookies: cookies },
params: {
consent: true,
title: SecureRandom.hex,
description: SecureRandom.hex
}
assert_response :precondition_required
# XXX: Como la cookie es lo primero que se verifica, si el sitio
# no existe tampoco se va a encontrar la cookie correcta.
assert_equal 'expired_or_invalid_cookie', response.body
end
test 'antes hay que pedir una cookie' do
assert_equal 2, @site.posts.size
get v1_site_invitades_cookie_url(@site.hostname, **@host)
post v1_site_posts_url(@site.hostname, layout: :post, **@host),
headers: {
cookies: cookies,
origin: @site.url
},
params: {
consent: true,
title: SecureRandom.hex,
description: SecureRandom.hex
}
@site.reload
assert_equal 3, @site.posts.size
assert_response :redirect
end
test 'no se pueden enviar algunos valores' do
uuid = SecureRandom.uuid
date = Date.today + 2.days
slug = SecureRandom.hex
desc = SecureRandom.hex
title = SecureRandom.hex
order = (rand * 100).to_i
get v1_site_invitades_cookie_url(@site.hostname, **@host)
post v1_site_posts_url(@site.hostname, layout: :post, **@host),
headers: {
cookies: cookies,
origin: @site.url
},
params: {
consent: true,
title: title,
description: desc,
uuid: uuid,
date: date,
slug: slug,
order: order
}
@site.reload
p = @site.posts.find_by title: title
assert p
assert_equal desc, p.description.value
assert_not_equal uuid, p.uuid.value
assert_not_equal slug, p.slug.value
assert_not_equal order, p.order.value
assert_not_equal date, p.date.value
end
test 'las cookies tienen un vencimiento interno' do
assert_equal 2, @site.posts.size
get v1_site_invitades_cookie_url(@site.hostname, **@host)
expired = (ENV.fetch('COOKIE_DURATION', '30').to_i + 1).minutes
Timecop.freeze(Time.now + expired) do
post v1_site_posts_url(@site.hostname, layout: :post, **@host),
headers: {
cookies: cookies,
origin: @site.url
},
params: {
post: {
title: SecureRandom.hex,
description: SecureRandom.hex
}
}
end
@site.reload
assert_response :precondition_required
assert_equal 2, @site.posts.size
assert_equal 'expired_or_invalid_cookie', response.body
end
end
end
end