mirror of
https://github.com/internetee/registry.git
synced 2025-06-12 15:44:45 +02:00
Merge remote-tracking branch 'origin/registry-791' into registry-791
This commit is contained in:
commit
96b02ed8d5
4 changed files with 26 additions and 14 deletions
|
@ -11,6 +11,7 @@ module Concerns::Domain::ForceDelete
|
||||||
self.force_delete_at = (Time.zone.now + (Setting.redemption_grace_period.days + 1.day)).utc
|
self.force_delete_at = (Time.zone.now + (Setting.redemption_grace_period.days + 1.day)).utc
|
||||||
.beginning_of_day
|
.beginning_of_day
|
||||||
stop_all_pending_actions
|
stop_all_pending_actions
|
||||||
|
allow_deletion
|
||||||
save(validate: false)
|
save(validate: false)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -26,8 +27,6 @@ module Concerns::Domain::ForceDelete
|
||||||
private
|
private
|
||||||
|
|
||||||
def stop_all_pending_actions
|
def stop_all_pending_actions
|
||||||
statuses.delete(DomainStatus::CLIENT_DELETE_PROHIBITED)
|
|
||||||
statuses.delete(DomainStatus::SERVER_DELETE_PROHIBITED)
|
|
||||||
statuses.delete(DomainStatus::PENDING_UPDATE)
|
statuses.delete(DomainStatus::PENDING_UPDATE)
|
||||||
statuses.delete(DomainStatus::PENDING_TRANSFER)
|
statuses.delete(DomainStatus::PENDING_TRANSFER)
|
||||||
statuses.delete(DomainStatus::PENDING_RENEW)
|
statuses.delete(DomainStatus::PENDING_RENEW)
|
||||||
|
@ -63,4 +62,9 @@ module Concerns::Domain::ForceDelete
|
||||||
statuses.delete(DomainStatus::PENDING_DELETE)
|
statuses.delete(DomainStatus::PENDING_DELETE)
|
||||||
statuses.delete(DomainStatus::SERVER_MANUAL_INZONE)
|
statuses.delete(DomainStatus::SERVER_MANUAL_INZONE)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def allow_deletion
|
||||||
|
statuses.delete(DomainStatus::CLIENT_DELETE_PROHIBITED)
|
||||||
|
statuses.delete(DomainStatus::SERVER_DELETE_PROHIBITED)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -617,6 +617,7 @@ class Domain < ActiveRecord::Base
|
||||||
hash = super
|
hash = super
|
||||||
hash['auth_info'] = hash.delete('transfer_code') # API v1 requirement
|
hash['auth_info'] = hash.delete('transfer_code') # API v1 requirement
|
||||||
hash['valid_from'] = hash['registered_at'] # API v1 requirement
|
hash['valid_from'] = hash['registered_at'] # API v1 requirement
|
||||||
|
hash.delete('statuses_before_force_delete')
|
||||||
hash
|
hash
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -63,10 +63,7 @@ Content-Type: application/json
|
||||||
],
|
],
|
||||||
"reserved": false,
|
"reserved": false,
|
||||||
"status_notes": {
|
"status_notes": {
|
||||||
},
|
}
|
||||||
"statuses_backup": [
|
|
||||||
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"total_number_of_records": 2
|
"total_number_of_records": 2
|
||||||
|
|
|
@ -21,7 +21,7 @@ class DomainForceDeleteTest < ActiveSupport::TestCase
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_scheduling_force_delete_adds_corresponding_statuses
|
def test_scheduling_force_delete_adds_corresponding_statuses
|
||||||
statuses = [
|
statuses_to_be_added = [
|
||||||
DomainStatus::FORCE_DELETE,
|
DomainStatus::FORCE_DELETE,
|
||||||
DomainStatus::SERVER_RENEW_PROHIBITED,
|
DomainStatus::SERVER_RENEW_PROHIBITED,
|
||||||
DomainStatus::SERVER_TRANSFER_PROHIBITED,
|
DomainStatus::SERVER_TRANSFER_PROHIBITED,
|
||||||
|
@ -31,23 +31,33 @@ class DomainForceDeleteTest < ActiveSupport::TestCase
|
||||||
|
|
||||||
@domain.schedule_force_delete
|
@domain.schedule_force_delete
|
||||||
@domain.reload
|
@domain.reload
|
||||||
assert (@domain.statuses & statuses) == statuses
|
assert (@domain.statuses & statuses_to_be_added) == statuses_to_be_added
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_scheduling_force_delete_allows_domain_deletion
|
||||||
|
statuses_to_be_removed = [
|
||||||
|
DomainStatus::CLIENT_DELETE_PROHIBITED,
|
||||||
|
DomainStatus::SERVER_DELETE_PROHIBITED,
|
||||||
|
]
|
||||||
|
|
||||||
|
@domain.statuses = statuses_to_be_removed + %w[other-status]
|
||||||
|
@domain.schedule_force_delete
|
||||||
|
@domain.reload
|
||||||
|
assert_empty @domain.statuses & statuses_to_be_removed
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_scheduling_force_delete_stops_pending_actions
|
def test_scheduling_force_delete_stops_pending_actions
|
||||||
statuses = [
|
statuses_to_be_removed = [
|
||||||
DomainStatus::CLIENT_DELETE_PROHIBITED,
|
|
||||||
DomainStatus::SERVER_DELETE_PROHIBITED,
|
|
||||||
DomainStatus::PENDING_UPDATE,
|
DomainStatus::PENDING_UPDATE,
|
||||||
DomainStatus::PENDING_TRANSFER,
|
DomainStatus::PENDING_TRANSFER,
|
||||||
DomainStatus::PENDING_RENEW,
|
DomainStatus::PENDING_RENEW,
|
||||||
DomainStatus::PENDING_CREATE,
|
DomainStatus::PENDING_CREATE,
|
||||||
]
|
]
|
||||||
|
|
||||||
@domain.statuses = statuses + %w[other-status]
|
@domain.statuses = statuses_to_be_removed + %w[other-status]
|
||||||
@domain.schedule_force_delete
|
@domain.schedule_force_delete
|
||||||
@domain.reload
|
@domain.reload
|
||||||
assert_not (@domain.statuses & statuses).any?, 'Pending actions should be stopped'
|
assert_empty @domain.statuses & statuses_to_be_removed, 'Pending actions should be stopped'
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_scheduling_force_delete_preserves_current_statuses
|
def test_scheduling_force_delete_preserves_current_statuses
|
||||||
|
@ -103,7 +113,7 @@ class DomainForceDeleteTest < ActiveSupport::TestCase
|
||||||
@domain.cancel_force_delete
|
@domain.cancel_force_delete
|
||||||
@domain.reload
|
@domain.reload
|
||||||
|
|
||||||
assert (@domain.statuses & statuses).empty?
|
assert_empty @domain.statuses & statuses
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_cancelling_force_delete_restores_statuses_that_a_domain_had_before_force_delete
|
def test_cancelling_force_delete_restores_statuses_that_a_domain_had_before_force_delete
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue