feat(api): expose import status details (#1599)

* feat(api): expose import status details

* fix(api): reuse import status validation counts

* fix(api): cache Sure import status reads

* fix(imports): invalidate cached Sure import blobs

* docs(api): split import status schemas

* fix(api): refine import status detail contract
This commit is contained in:
ghost
2026-05-01 14:59:32 -06:00
committed by GitHub
parent da42423475
commit c4414c4fbb
12 changed files with 240 additions and 7 deletions

View File

@@ -38,6 +38,12 @@ class Api::V1::ImportsControllerTest < ActionDispatch::IntegrationTest
json_response = JSON.parse(response.body)
assert_not_empty json_response["data"]
assert_equal @family.imports.count, json_response["meta"]["total_count"]
import_data = json_response["data"].detect { |data| data["id"] == @import.id }
assert_not_nil import_data
assert_equal @import.uploaded?, import_data["status_detail"]["uploaded"]
assert_equal @import.configured?, import_data["status_detail"]["configured"]
assert_equal @import.complete? || @import.failed? || @import.revert_failed?, import_data["status_detail"]["terminal"]
end
test "should show import" do
@@ -45,8 +51,26 @@ class Api::V1::ImportsControllerTest < ActionDispatch::IntegrationTest
assert_response :success
json_response = JSON.parse(response.body)
rows = @import.rows.to_a
valid_rows_count = rows.count(&:valid?)
invalid_rows_count = rows.length - valid_rows_count
assert_equal @import.id, json_response["data"]["id"]
assert_equal @import.status, json_response["data"]["status"]
assert json_response["data"].key?("status_detail")
assert_equal @import.uploaded?, json_response["data"]["status_detail"]["uploaded"]
assert_equal @import.configured?, json_response["data"]["status_detail"]["configured"]
assert_equal @import.cleaned_from_validation_stats?(invalid_rows_count: invalid_rows_count),
json_response["data"]["status_detail"]["cleaned"]
assert_equal @import.publishable_from_validation_stats?(invalid_rows_count: invalid_rows_count),
json_response["data"]["status_detail"]["publishable"]
assert_equal @import.revertable?, json_response["data"]["status_detail"]["revertable"]
assert_equal @import.rows_count, json_response["data"]["stats"]["rows_count"]
assert_equal valid_rows_count, json_response["data"]["stats"]["valid_rows_count"]
assert_equal invalid_rows_count, json_response["data"]["stats"]["invalid_rows_count"]
assert_equal @import.mappings.count, json_response["data"]["stats"]["mappings_count"]
assert_equal @import.mappings.where(mappable_id: nil).count,
json_response["data"]["stats"]["unassigned_mappings_count"]
end
test "should create import with raw content" do