Erreur bizarre de décalage d'un poste après la mise à jour

Je tente de mettre à jour un ensemble de publications dans un script Rails. Il semble y avoir un comportement étrange de type « off-by-one » où une publication est mise à jour avec la valeur de la publication précédente.

J’ai déplacé toutes ces mises à jour pour effectuer directement un post.raw.gsub() afin de « résoudre » ce problème pour les publications à l’intérieur de la boucle interne (qui récupéraient auparavant la valeur de la publication du sujet), mais maintenant la publication du sujet N est mise à jour avec le contenu brut de la dernière publication précédente du sujet N-1.

Je suis encore plus confus, car la première publication (c’est-à-dire celle du sujet) est mise à jour avec tpost.raw.gsub! utilisant la valeur de post.raw.gsub!(preg, "#{$2}") de l’itération précédente.

EDIT : Bon, je n’ai jamais vraiment compris ce qui clochait dans la dernière version, mais voici une version d’un script de mise à jour de certaines publications qui crée une révision :

def fix_slack_posts
  opts = { bypass_rate_limiter: true, bypass_bump: true, skip_validations: true }
  reg=/(\\*\\*)(This topic was automatically generated from Slack. You can find the original thread \\[here\\].+?\\))(\\*\\*\\.)?\\s*?([a-zA-Z, ()]* : )(.*)/m
  preg = /([a-zA-Z, ()]+? : )(.*)/m
  topic_posts = Post.where("raw like '**This topic was automatically%'")
  #topic_posts = Post.where(topic_id: [23934, 23935], post_number: 1)
  topic_posts.each do |tpost|
    begin
      puts "Fixing topic post #{tpost.id} with #{tpost.raw[0..30]}"
      puts tpost.raw.gsub(reg,"1 #{$1}\n2 #{$2}\n3 #{$3}\n4 #{$4}\n 5 #{$5}")
      raw = tpost.raw.gsub(reg,"#{$5}\n\n#{$2}.")
      puts "Fixing topic post #{tpost.id} with #{tpost.raw[0..30]}\n---\u003e#{raw}"
      user = User.find(tpost.user_id)
      if raw.length \u003e 10
        tpost.revise(user,{raw: raw,edit_reason: 'fix slack link location'}, opts)
      end
    rescue
      puts "Can't update topic post #{tpost.raw}"
    end
    posts = Post.where(topic_id: tpost.topic_id).where("post_number \u003e 1")
    posts.each do |post|
      if post.raw.gsub(preg,"#{$2}").length\u003e=10
        begin
          puts "Fixing post #{post.id} with #{post.raw[0..30]}"
          raw = post.raw.gsub(preg,"#{$2}")
          user = User.find(post.user_id)
          post.revise(user,{raw: raw,edit_reason: 'remove user name from text'}, opts)
        rescue
          puts "#{post.id}--cannot save #{post.raw}. "
        end
      end
    end
  end
end