Sha256: 1e493b6b02fd05097d168aa6acdc981d0f4f0e2e5807128b8291d1ca4779b5f5
Contents?: true
Size: 1.51 KB
Versions: 4
Compression:
Stored size: 1.51 KB
Contents
# frozen_string_literal: true require "cases/helper" require "models/post" class AnnotateTest < ActiveRecord::TestCase fixtures :posts def test_annotate_wraps_content_in_an_inline_comment quoted_posts_id, quoted_posts = regexp_escape_table_name("posts.id"), regexp_escape_table_name("posts") assert_sql(%r{\ASELECT #{quoted_posts_id} FROM #{quoted_posts} /\* foo \*/}i) do posts = Post.select(:id).annotate("foo") assert posts.first end end def test_annotate_is_sanitized quoted_posts_id, quoted_posts = regexp_escape_table_name("posts.id"), regexp_escape_table_name("posts") assert_sql(%r{\ASELECT #{quoted_posts_id} FROM #{quoted_posts} /\* foo \*/}i) do posts = Post.select(:id).annotate("*/foo/*") assert posts.first end assert_sql(%r{\ASELECT #{quoted_posts_id} FROM #{quoted_posts} /\* foo \*/}i) do posts = Post.select(:id).annotate("**//foo//**") assert posts.first end assert_sql(%r{\ASELECT #{quoted_posts_id} FROM #{quoted_posts} /\* foo \*/ /\* bar \*/}i) do posts = Post.select(:id).annotate("*/foo/*").annotate("*/bar") assert posts.first end assert_sql(%r{\ASELECT #{quoted_posts_id} FROM #{quoted_posts} /\* \+ MAX_EXECUTION_TIME\(1\) \*/}i) do posts = Post.select(:id).annotate("+ MAX_EXECUTION_TIME(1)") assert posts.first end end private def regexp_escape_table_name(name) Regexp.escape(Post.connection.quote_table_name(name)) end end
Version data entries
4 entries across 4 versions & 1 rubygems