此警报已接触,请直接升级到rails3.1.0.rc5 和 sprockets.2.0.0.beta.13
sprockets-2.0.0.beta.10以后版本的一个微小改动会让r3.1的assets pipeline无法找到assets资源。
sprockets目前的版本是2.0.0.beta.12,一个多月前发布的2.0.0.beta.11版本已经出现同样问题,所幸在那个版本发布后不久就被从gem库中移除(也许就是因为这个问题),但刚刚发布的2.0.0.beta.12依然没有做出针对性的修复。
这个引发问题的改动很简单,但是我自己对于这个问题的修复很矛盾。这个问题的原因是一个看起来相当有道理的变化,故事说起来有点长,简单的举个例子来说明:
原因是由于一个数组赋值的语句发生了一点微小的变化:
在sprockets-2.0.0.beta.10是这么作的:
#需求是把b数组拼接到a数组里
a = [ 1 , 2 , 3 ]
b = [ 4 , 5 , 6 ]
#在sprockets-2.0.0.beta.10是这么实现的
a.concat b #=> a = [ 1 , 2 , 3 , 4 , 5 , 6 ]
从sprockets-2.0.0.beta.11以后版本是这么作的:
#需求是把b数组拼接到a数组里
a = [ 1 , 2 , 3 ]
b = [ 4 , 5 , 6 ]
#在sprockets-2.0.0.beta.11以后是这么实现的
a.dup.concat b #=> 毫无疑问: a = [ 1 , 2 , 3 ]
想确认的同学可以在console下反复输入几次以下代码:
Rails.application.assets.paths.id
在sprockets-2.0.0.beta.10下每次返回的结果都是一样的,在sprockets-2.0.0.beta.11以后每次结果都不一样,就是因为这个paths方法里多了个dup。
对于这个问题我决定不自己动手修复,一方面sprocket没有什么错,为一个array作getter,出于数据安全的考虑,用dup是可以理解的;另一方面,rails本身也确实没有什么更好的办法来接触这个对象。在哪头改好像都不太合适,干脆等他们自己掰吃明白的吧。