Skip to content

Commit

Permalink
Revert "fix(cleanup): Improve delete orphans SQL query (#527)"
Browse files Browse the repository at this point in the history
This reverts commit 853354e.
  • Loading branch information
bethesque authored Dec 2, 2021
1 parent 5f295f1 commit 12fd76c
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 32 deletions.
9 changes: 0 additions & 9 deletions docs/configuration.yml
Original file line number Diff line number Diff line change
Expand Up @@ -100,15 +100,6 @@ groups:
default_value: 5
allowed_values_description: A positive integer or float, as a string.
more_info: https://sequel.jeremyevans.net/rdoc/files/doc/opening_databases_rdoc.html#label-General+connection+options
sql_enable_caller_logging:
description: |-
Whether or not to enable caller_logging extension for database connection.
When enabled it logs source path that caused SQL query.
default_value: false
allowed_values:
- true
- false
more_info: https://sequel.jeremyevans.net/rdoc-plugins/files/lib/sequel/extensions/caller_logging_rb.html
database_max_connections:
description: "The maximum size of the connection pool (4 connections by default on most databases)"
default_value: 4
Expand Down
19 changes: 2 additions & 17 deletions lib/pact_broker/db/clean_incremental.rb
Original file line number Diff line number Diff line change
Expand Up @@ -92,23 +92,8 @@ def dry_run?
end

def delete_orphan_pact_versions
db[:pact_versions].where(id: orphan_pact_versions).delete
rescue Sequel::DatabaseError => e
raise unless e.cause.class.name == "Mysql2::Error"

ids = orphan_pact_versions.map { |row| row[:id] }
db[:pact_versions].where(id: ids).delete
end

def orphan_pact_versions
db[:pact_versions]
.left_join(:pact_publications, pact_version_id: :id)
.left_join(:verifications, pact_version_id: :id)
.select(Sequel[:pact_versions][:id])
.where(
Sequel[:pact_publications][:id] => nil,
Sequel[:verifications][:id] => nil
)
referenced_pact_version_ids = db[:pact_publications].select(:pact_version_id).union(db[:verifications].select(:pact_version_id))
db[:pact_versions].where(id: referenced_pact_version_ids).invert.delete
end

def version_info(version)
Expand Down
8 changes: 5 additions & 3 deletions spec/lib/pact_broker/db/clean_incremental_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@

module PactBroker
module DB
describe CleanIncremental do
# Inner queries don't work on MySQL. Seriously, MySQL???
xdescribe CleanIncremental do
def pact_publication_count_for(consumer_name, version_number)
PactBroker::Pacts::PactPublication.where(consumer_version: PactBroker::Domain::Version.where_pacticipant_name(consumer_name).where(number: version_number)).count
end
Expand Down Expand Up @@ -84,13 +85,14 @@ def pact_publication_count_for(consumer_name, version_number)
expect { subject }.to_not change { PactBroker::Domain::Version.count }
end

# Randomly fails on github actions, never locally :shrug:
it "returns info on what will be deleted", skip: ENV["CI"] == "true" do
# Always fails on github actions, never locally :shrug:
it "returns info on what will be deleted", pending: ENV["CI"] == "true" do
Approvals.verify(subject, :name => "clean_incremental_dry_run", format: :json)
end
end
end


context "with orphan pact versions" do
before do
# Create a pact that will not be deleted
Expand Down
6 changes: 3 additions & 3 deletions spec/lib/pact_broker/verifications/repository_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,9 @@ module Verifications

it "creates a PactVersionProviderTagSuccessfulVerification for each tag" do
expect { subject }.to change { PactVersionProviderTagSuccessfulVerification.count }.by(2)
expect(PactVersionProviderTagSuccessfulVerification.all).to contain_exactly(
have_attributes(wip: false, provider_version_tag_name: "foo"),
have_attributes(wip: false, provider_version_tag_name: "bar"),
expect(PactVersionProviderTagSuccessfulVerification.first).to have_attributes(
wip: false,
provider_version_tag_name: "foo"
)
end
end
Expand Down

0 comments on commit 12fd76c

Please sign in to comment.