Loop collection and update after functions


The last week I try this code to work. It is not possible to update the collections inside a loop. It will insert the data to de Tags collections, but it is not possible to update the collections Monitor. I try the code with Fiber and promise, but it didn’t work.
This is the code

import psi from 'psi';
import ping from 'ping'
import { Meteor } from 'meteor/meteor';
// Get the PageSpeed Insights report
Meteor.startup(function() {
  console.log("Minitor gestart");
  Meteor.setInterval(task, 10000);


function task() {
  Monitor.find().forEach(function(item) {
    ping.sys.probe(item.url, function(isAlive) {
      if (isAlive) {
        psi(item.url, {
          key: 'xxxxxxxxxxxxxxxx',
          strategy: 'mobile'
        }).then(data => {
          inserttig(item, 1, data.ruleGroups);
          updateok(item, 1);
      } else {
        inserttig(item, 0, null);

function updateok(item, status) {
      _id: item._id
    }, {
      $set: {
        status: status,
        nextcheck: moment().add(item.interval, 'minutes').toDate()
    }, function(error, result) {
      if (error) reject(error)
      else resolve(result)

function inserttig(item, status, data) {
    monitor: item._id,
    status: status,
    value: data,
    datum: new Date()
  }, function(error, result) {
    if (error) console.log(error);

I think you need to fetch –

Monitor.find().forEach(function(item) {

should be

Monitor.find().fetch().forEach(function(item) {

I am sorry. I changed the code but the collection items woun’t update.

Do you see any errors? I’d expect to see Meteor complaining about the update code not running in a fiber. Based on your console logs, how far are things getting? Is the method getting called?