FIX: Respect date range in top traffic sources report (#25599)

See https://meta.discourse.org/t/reports-top-traffic-sources-topics-stat-issue/179850
This commit is contained in:
Penar Musaraj 2024-02-08 11:17:59 -05:00 committed by GitHub
parent a3ef9e92eb
commit 6bd26e81c1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 46 additions and 1 deletions

View File

@ -138,6 +138,8 @@ class IncomingLinksReport
num_clicks.keys, num_clicks.keys,
category_id: report.category_id, category_id: report.category_id,
include_subcategories: report.include_subcategories, include_subcategories: report.include_subcategories,
start_date: report.start_date,
end_date: report.end_date,
) )
report.data = [] report.data = []
num_clicks.each_key do |domain| num_clicks.each_key do |domain|
@ -176,7 +178,12 @@ class IncomingLinksReport
include_subcategories: options[:include_subcategories], include_subcategories: options[:include_subcategories],
) )
.joins(incoming_referer: :incoming_domain) .joins(incoming_referer: :incoming_domain)
.where("incoming_links.created_at > ? AND incoming_domains.name IN (?)", 30.days.ago, domains) .where(
"incoming_links.created_at > ? AND incoming_links.created_at < ?",
options[:start_date],
options[:end_date],
)
.where("incoming_domains.name IN (?)", domains)
.group("incoming_domains.name") .group("incoming_domains.name")
end end

View File

@ -127,6 +127,44 @@ RSpec.describe IncomingLinksReport do
}, },
] ]
end end
it "respects date ranges" do
p1 = create_post
p1.topic.save
p2 = create_post
p2.topic.save
2.times do |n|
IncomingLink.create(
referer: "http://test.com",
post_id: p1.id,
ip_address: "10.0.0.#{n}",
user_id: p1.user.id,
created_at: 2.days.ago,
)
end
3.times do |n|
IncomingLink.create(
referer: "http://yowza.com",
post_id: p2.id,
ip_address: "10.0.0.#{n}",
user_id: p2.user.id,
created_at: 2.months.ago,
)
end
r = IncomingLinksReport.find("top_traffic_sources").as_json
expect(r[:data]).to eq [{ domain: "test.com", num_clicks: 2, num_topics: 1 }]
r2 =
IncomingLinksReport.find(
"top_traffic_sources",
{ start_date: 3.months.ago, end_date: 1.month.ago },
).as_json
expect(r2[:data]).to eq [{ domain: "yowza.com", num_clicks: 3, num_topics: 1 }]
end
end end
describe "top_referrers" do describe "top_referrers" do