mirror of
https://github.com/discourse/discourse.git
synced 2025-01-06 04:44:10 +08:00
4ea21fa2d0
This change both speeds up specs (less strings to allocate) and helps catch cases where methods in Discourse are mutating inputs. Overall we will be migrating everything to use #frozen_string_literal: true it will take a while, but this is the first and safest move in this direction
55 lines
1.8 KiB
Ruby
55 lines
1.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
require "file_store/s3_store"
|
|
|
|
describe Jobs::UpdateS3Inventory do
|
|
before do
|
|
SiteSetting.enable_s3_uploads = true
|
|
SiteSetting.s3_access_key_id = "abc"
|
|
SiteSetting.s3_secret_access_key = "def"
|
|
SiteSetting.enable_s3_inventory = true
|
|
|
|
store = FileStore::S3Store.new
|
|
@client = Aws::S3::Client.new(stub_responses: true)
|
|
store.s3_helper.stubs(:s3_client).returns(@client)
|
|
Discourse.stubs(:store).returns(store)
|
|
end
|
|
|
|
it "updates the bucket policy and inventory configuration in S3" do
|
|
id = "original"
|
|
path = File.join(S3Inventory::INVENTORY_PREFIX, S3Inventory::INVENTORY_VERSION)
|
|
|
|
@client.expects(:put_bucket_policy).with(
|
|
bucket: "bucket",
|
|
policy: "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Sid\":\"InventoryAndAnalyticsPolicy\",\"Effect\":\"Allow\",\"Principal\":{\"Service\":\"s3.amazonaws.com\"},\"Action\":[\"s3:PutObject\"],\"Resource\":[\"arn:aws:s3:::bucket/#{path}/*\"],\"Condition\":{\"ArnLike\":{\"aws:SourceArn\":\"arn:aws:s3:::bucket\"},\"StringEquals\":{\"s3:x-amz-acl\":\"bucket-owner-full-control\"}}}]}"
|
|
)
|
|
@client.expects(:put_bucket_inventory_configuration)
|
|
@client.expects(:put_bucket_inventory_configuration).with(
|
|
bucket: "bucket",
|
|
id: id,
|
|
inventory_configuration: {
|
|
destination: {
|
|
s3_bucket_destination: {
|
|
bucket: "arn:aws:s3:::bucket",
|
|
prefix: path,
|
|
format: "CSV"
|
|
}
|
|
},
|
|
filter: {
|
|
prefix: id
|
|
},
|
|
is_enabled: true,
|
|
id: id,
|
|
included_object_versions: "Current",
|
|
optional_fields: ["ETag"],
|
|
schedule: { frequency: "Daily" }
|
|
},
|
|
use_accelerate_endpoint: false
|
|
)
|
|
|
|
described_class.new.execute(nil)
|
|
end
|
|
|
|
end
|