Why does 'extend ActiveSupport::Concern' cause `undefined method 'recycle!'`?

619 views
Skip to first unread message

Weston Platter

unread,
Dec 1, 2012, 6:19:31 PM12/1/12
to rubyonra...@googlegroups.com
Working on Rails Engine.

I want to make the controllers customizable whereever the Rails Engine is used.

Therefore, I was trying to use `extend ActiveSupport::Concern` on the Engine controller class and include it in MyRailsApp.


# code in my rails engine

moduel MyEngine
  class SomeController
    extend ActiveSupport::Concern
  
    def engine_some_method
    end
  end
end


# code in my rails app where engine is implemented

class SomeController
  include MyEngine::SomeController

  def app_some_method
  end

  # code that's available by including the Rails Engine code
  # def engine_some_method
  # end
end

But, this breaks my rpsec controller tests because of an undefined "recycle" method.

12) Qe::Admin::QuestionPagesController POST reorder
     Failure/Error: xhr :post, :create,
     NoMethodError:
       undefined method `recycle!' for #<Qe::Admin::QuestionPagesController:0x007f80aa1c7528>
     # ./spec/controllers/admin/pages_controller_spec.rb:69:in `block (2 levels) in <top (required)>'

When I comment out the "include MyEngine::Controller" everything passes.

Why?

Frederick Cheung

unread,
Dec 1, 2012, 8:11:02 PM12/1/12
to Ruby on Rails: Talk


On Dec 1, 7:19 pm, Weston Platter <westonplat...@gmail.com> wrote:

>
> But, this breaks my rpsec controller tests because of an undefined
> "recycle" method.
>
> 12) Qe::Admin::QuestionPagesController POST reorder
>      Failure/Error: xhr :post, :create,
>      NoMethodError:
>        undefined method `recycle!' for
> #<Qe::Admin::QuestionPagesController:0x007f80aa1c7528>
>      # ./spec/controllers/admin/pages_controller_spec.rb:69:in `block (2
> levels) in <top (required)>'
>
> When I comment out the "include MyEngine::Controller" everything passes.
>

If it's commenting out the include that fixes things, why are you so
sure that it's the extend at fault rather than something else in the
module? Personally I'd be inclined to thing that by including your
module you're accidentally shadowing an existing method on the
controller - if you were to show a minimal example that reproduces the
problem rather than dummy code someone might be able to have a guess
(I suspect the issue may have been lost in translation from your
actual code to the example you gave since the latter isn't valid ruby
(for example you're including a class rather than a module)

Fred
> Why?

Weston Platter

unread,
Dec 2, 2012, 6:22:59 PM12/2/12
to rubyonra...@googlegroups.com
What you said makes sense. 

I incorrectly said I commented out
include MyEngine::SomeController

when I meant to say commenting out 
extend ActiveSupport::Concern

Frederick Cheung

unread,
Dec 2, 2012, 8:00:42 PM12/2/12
to Ruby on Rails: Talk


On Dec 2, 7:22 pm, Weston Platter <westonplat...@gmail.com> wrote:
> What you said makes sense.
>
> I incorrectly said I commented out
> include MyEngine::SomeController
>
> when I meant to say commenting out
> extend ActiveSupport::Concern
>

Calling extend activesupport::concern on a controller sounds like a
weird thing to do
- it's supposed to be used on modules. What were you trying to do
with it?

Fred


> fixes the issue.
>
> The codeabse is here,https://github.com/twinge/questionnaire_engine/tree/8836c2a3b92e676ea...
> .
>
> The specific Controller Class is here,https://github.com/twinge/questionnaire_engine/blob/8836c2a3b92e676ea...
>
> The specific Controller Spec test is here,https://github.com/twinge/questionnaire_engine/blob/8836c2a3b92e676ea...

Frederick Cheung

unread,
Dec 2, 2012, 8:06:31 PM12/2/12
to Ruby on Rails: Talk


On Dec 2, 9:00 pm, Frederick Cheung <frederick.che...@gmail.com>
wrote:
> On Dec 2, 7:22 pm, Weston Platter <westonplat...@gmail.com> wrote:
>
> > What you said makes sense.
>
> > I incorrectly said I commented out
> > include MyEngine::SomeController
>
> > when I meant to say commenting out
> > extend ActiveSupport::Concern
>
> Calling extend activesupport::concern on a controller sounds like a
> weird thing to do
>  - it's supposed to be used on modules. What were you trying to do
> with it?

And I assume that the reason this causes a problem is something to do
with how as::concern changes the behaviour of include so as to setup
module dependencies.

Weston Platter

unread,
Dec 8, 2012, 1:51:50 PM12/8/12
to rubyonra...@googlegroups.com
I think I need to wrap class methods in a "module ClassMethods" block.

require 'active_support/concern'

module M
  extend ActiveSupport::Concern

  included do
    scope :disabled, where(:disabled => true)
  end

  module ClassMethods
    ...
  end
end

Frederick Cheung

unread,
Dec 9, 2012, 11:25:03 AM12/9/12
to rubyonra...@googlegroups.com


On Saturday, December 8, 2012 6:51:50 PM UTC, Weston Platter wrote:
I think I need to wrap class methods in a "module ClassMethods" block.

Yes, that's the way to add class methods with AS::Concern.

Fred
 

> > > > Why?
Reply all
Reply to author
Forward
0 new messages