2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-11-08 09:57:01 +08:00
|
|
|
RSpec.describe DbHelper do
|
2024-12-12 00:23:30 +08:00
|
|
|
fab!(:sidebar_url1) { Fabricate(:sidebar_url, name: "short-sidebar-url") }
|
|
|
|
fab!(:sidebar_url2) { Fabricate(:sidebar_url, name: "another-sidebar-url") }
|
|
|
|
let(:sidebar_url_name_limit) { SidebarUrl.columns_hash["name"].limit }
|
|
|
|
let(:long_sidebar_url_name) { "a" * (sidebar_url_name_limit + 1) }
|
2024-11-15 18:42:25 +08:00
|
|
|
|
2024-11-25 19:39:53 +08:00
|
|
|
describe ".remap" do
|
2018-11-08 09:57:01 +08:00
|
|
|
it "should remap columns properly" do
|
|
|
|
post = Fabricate(:post, cooked: "this is a specialcode that I included")
|
|
|
|
post_attributes = post.reload.attributes
|
|
|
|
|
|
|
|
badge = Fabricate(:badge, query: "specialcode")
|
|
|
|
badge_attributes = badge.reload.attributes
|
|
|
|
|
|
|
|
DbHelper.remap("specialcode", "codespecial")
|
|
|
|
|
|
|
|
post.reload
|
|
|
|
|
|
|
|
expect(post.cooked).to include("codespecial")
|
|
|
|
|
|
|
|
badge.reload
|
|
|
|
|
|
|
|
expect(badge.query).to eq("codespecial")
|
|
|
|
|
|
|
|
expect(badge_attributes.except("query")).to eq(badge.attributes.except("query"))
|
|
|
|
end
|
2018-11-08 12:28:50 +08:00
|
|
|
|
|
|
|
it "allows tables to be excluded from scanning" do
|
|
|
|
post = Fabricate(:post, cooked: "test")
|
|
|
|
|
2018-12-27 00:34:49 +08:00
|
|
|
DbHelper.remap("test", "something else", excluded_tables: %w[posts])
|
2018-11-08 12:28:50 +08:00
|
|
|
|
|
|
|
expect(post.reload.cooked).to eq("test")
|
|
|
|
end
|
2019-05-10 00:01:35 +08:00
|
|
|
|
|
|
|
it "does not remap readonly columns" do
|
|
|
|
post = Fabricate(:post, raw: "This is a test", cooked: "This is a test")
|
|
|
|
|
|
|
|
Migration::ColumnDropper.mark_readonly("posts", "cooked")
|
|
|
|
|
|
|
|
DbHelper.remap("test", "something else")
|
|
|
|
|
|
|
|
post.reload
|
|
|
|
|
|
|
|
expect(post.raw).to eq("This is a something else")
|
|
|
|
expect(post.cooked).to eq("This is a test")
|
|
|
|
|
|
|
|
DB.exec "DROP FUNCTION #{Migration::BaseDropper.readonly_function_name("posts", "cooked")} CASCADE"
|
|
|
|
end
|
2024-11-15 18:42:25 +08:00
|
|
|
|
|
|
|
context "when skip_max_length_violations is false" do
|
|
|
|
it "raises an exception if remap exceeds column length constraint by default" do
|
2024-12-12 00:23:30 +08:00
|
|
|
expect { DbHelper.remap("sidebar-url", long_sidebar_url_name) }.to raise_error(
|
2024-11-15 18:42:25 +08:00
|
|
|
PG::StringDataRightTruncation,
|
2024-12-12 00:23:30 +08:00
|
|
|
/value too long.*table: sidebar_urls,.*name/,
|
2024-11-15 18:42:25 +08:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when skip_max_length_violations is true" do
|
|
|
|
it "skips a remap eligible row if new value exceeds column length constraint" do
|
2024-12-12 00:23:30 +08:00
|
|
|
DbHelper.remap("sidebar-url", long_sidebar_url_name, skip_max_length_violations: true)
|
2024-11-15 18:42:25 +08:00
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
sidebar_url1.reload
|
|
|
|
sidebar_url2.reload
|
2024-11-15 18:42:25 +08:00
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
expect(sidebar_url1.name).to eq("short-sidebar-url")
|
|
|
|
expect(sidebar_url2.name).to eq("another-sidebar-url")
|
2024-11-15 18:42:25 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it "logs skipped remaps due to max length constraints when verbose is true" do
|
|
|
|
expect {
|
|
|
|
DbHelper.remap(
|
2024-12-12 00:23:30 +08:00
|
|
|
"sidebar-url",
|
|
|
|
long_sidebar_url_name,
|
2024-11-15 18:42:25 +08:00
|
|
|
verbose: true,
|
|
|
|
skip_max_length_violations: true,
|
|
|
|
)
|
|
|
|
}.to output(/SKIPPED:/).to_stdout
|
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
sidebar_url1.reload
|
|
|
|
sidebar_url2.reload
|
2024-11-15 18:42:25 +08:00
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
expect(sidebar_url1.name).to eq("short-sidebar-url")
|
|
|
|
expect(sidebar_url2.name).to eq("another-sidebar-url")
|
2024-11-15 18:42:25 +08:00
|
|
|
end
|
|
|
|
end
|
2018-11-08 09:57:01 +08:00
|
|
|
end
|
2019-03-22 16:21:43 +08:00
|
|
|
|
|
|
|
describe ".regexp_replace" do
|
|
|
|
it "should remap columns correctly" do
|
|
|
|
post = Fabricate(:post, raw: "this is a [img]test[/img] post")
|
|
|
|
|
|
|
|
DbHelper.regexp_replace("\\[img\\]test\\[/img\\]", "[img]something[/img]")
|
|
|
|
|
|
|
|
expect(post.reload.raw).to include("[img]something[/img]")
|
|
|
|
end
|
2024-11-25 19:39:53 +08:00
|
|
|
|
|
|
|
context "when skip_max_length_violations is false" do
|
|
|
|
it "raises an exception if regexp_replace exceeds column length constraint by default" do
|
2024-12-12 00:23:30 +08:00
|
|
|
expect { DbHelper.regexp_replace("sidebar-url", long_sidebar_url_name) }.to raise_error(
|
2024-11-25 19:39:53 +08:00
|
|
|
PG::StringDataRightTruncation,
|
2024-12-12 00:23:30 +08:00
|
|
|
/value too long.*table: sidebar_urls,.*name/,
|
2024-11-25 19:39:53 +08:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when skip_max_length_violations is true" do
|
|
|
|
it "skips regexp_replace eligible rows if new value exceeds column length constraint" do
|
2024-12-12 00:23:30 +08:00
|
|
|
DbHelper.regexp_replace(
|
|
|
|
"sidebar-url",
|
|
|
|
long_sidebar_url_name,
|
|
|
|
skip_max_length_violations: true,
|
|
|
|
)
|
2024-11-25 19:39:53 +08:00
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
sidebar_url1.reload
|
|
|
|
sidebar_url2.reload
|
2024-11-25 19:39:53 +08:00
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
expect(sidebar_url1.name).to eq("short-sidebar-url")
|
|
|
|
expect(sidebar_url2.name).to eq("another-sidebar-url")
|
2024-11-25 19:39:53 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it "logs skipped regexp_replace due to max length constraints when verbose is true" do
|
|
|
|
expect {
|
|
|
|
DbHelper.regexp_replace(
|
2024-12-12 00:23:30 +08:00
|
|
|
"sidebar-url",
|
|
|
|
long_sidebar_url_name,
|
2024-11-25 19:39:53 +08:00
|
|
|
verbose: true,
|
|
|
|
skip_max_length_violations: true,
|
|
|
|
)
|
|
|
|
}.to output(/SKIPPED:/).to_stdout
|
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
sidebar_url1.reload
|
|
|
|
sidebar_url2.reload
|
2024-11-25 19:39:53 +08:00
|
|
|
|
2024-12-12 00:23:30 +08:00
|
|
|
expect(sidebar_url1.name).to eq("short-sidebar-url")
|
|
|
|
expect(sidebar_url2.name).to eq("another-sidebar-url")
|
2024-11-25 19:39:53 +08:00
|
|
|
end
|
|
|
|
end
|
2019-03-22 16:21:43 +08:00
|
|
|
end
|
2018-11-08 09:57:01 +08:00
|
|
|
end
|