aboutsummaryrefslogtreecommitdiffstats
path: root/activestorage/test
diff options
context:
space:
mode:
authorJonathan Boler <galatians@gmail.com>2018-06-04 12:59:43 -0500
committerJonathan Boler <galatians@gmail.com>2018-06-04 12:59:43 -0500
commit3674ccd444275fd17cc453add398985a43acb056 (patch)
tree08fbd968c6f5a1bb1e18f7aef9555b73d5cdc682 /activestorage/test
parente7758b8b68e33ca770fcedec0ae66e636276be08 (diff)
parent187ace068bba7c63c46ee869ac6cc35716f1b7ab (diff)
downloadrails-3674ccd444275fd17cc453add398985a43acb056.tar.gz
rails-3674ccd444275fd17cc453add398985a43acb056.tar.bz2
rails-3674ccd444275fd17cc453add398985a43acb056.zip
Merge branch 'master' of github.com:rails/rails
Diffstat (limited to 'activestorage/test')
-rw-r--r--activestorage/test/models/reflection_test.rb29
1 files changed, 29 insertions, 0 deletions
diff --git a/activestorage/test/models/reflection_test.rb b/activestorage/test/models/reflection_test.rb
new file mode 100644
index 0000000000..da866ca996
--- /dev/null
+++ b/activestorage/test/models/reflection_test.rb
@@ -0,0 +1,29 @@
+# frozen_string_literal: true
+
+require "test_helper"
+
+class ActiveStorage::ReflectionTest < ActiveSupport::TestCase
+ test "allows reflecting for all attachment" do
+ expected_classes =
+ User.reflect_on_all_attachments.all? do |reflection|
+ reflection.is_a?(ActiveStorage::Reflection::HasOneAttachedReflection) ||
+ reflection.is_a?(ActiveStorage::Reflection::HasManyAttachedReflection)
+ end
+
+ assert expected_classes
+ end
+
+ test "allows reflecting on a singular has_one_attached attachment" do
+ reflection = User.reflect_on_attachment(:avatar)
+
+ assert_equal :avatar, reflection.name
+ assert_equal :has_one_attached, reflection.macro
+ end
+
+ test "allows reflecting on a singular has_many_attached attachment" do
+ reflection = User.reflect_on_attachment(:highlights)
+
+ assert_equal :highlights, reflection.name
+ assert_equal :has_many_attached, reflection.macro
+ end
+end