From abda6d784eb0940b352cd28c28a3f3e87757a489 Mon Sep 17 00:00:00 2001 From: David Heinemeier Hansson Date: Wed, 5 Jul 2017 18:57:45 +0200 Subject: Basic MirrorSite Still need to convert it to threading --- test/site/mirror_site_test.rb | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 test/site/mirror_site_test.rb (limited to 'test') diff --git a/test/site/mirror_site_test.rb b/test/site/mirror_site_test.rb new file mode 100644 index 0000000000..326edb2f9c --- /dev/null +++ b/test/site/mirror_site_test.rb @@ -0,0 +1,30 @@ +require "tmpdir" +require "site/shared_site_tests" + +class ActiveVault::Site::MirrorSiteTest < ActiveSupport::TestCase + PRIMARY_DISK_SITE = ActiveVault::Site.configure(:Disk, root: File.join(Dir.tmpdir, "active_vault")) + SECONDARY_DISK_SITE = ActiveVault::Site.configure(:Disk, root: File.join(Dir.tmpdir, "active_vault_mirror")) + + SITE = ActiveVault::Site.configure :Mirror, sites: [ PRIMARY_DISK_SITE, SECONDARY_DISK_SITE ] + + include ActiveVault::Site::SharedSiteTests + + test "uploading was done to all sites" do + begin + key = SecureRandom.base58(24) + data = "Something else entirely!" + io = StringIO.new(data) + @site.upload(key, io) + + assert_equal data, PRIMARY_DISK_SITE.download(key) + assert_equal data, SECONDARY_DISK_SITE.download(key) + ensure + @site.delete key + end + end + + test "existing in all sites" do + assert PRIMARY_DISK_SITE.exist?(FIXTURE_KEY) + assert SECONDARY_DISK_SITE.exist?(FIXTURE_KEY) + end +end -- cgit v1.2.3