console.log nie pokazuje oczekiwanych właściwości obiektu

Mam następujący kod w javascript w mojej aplikacji node.js. Jednak niektóre obiekty nie są przechowywane w mojej zmiennejappointment. Nawet jeśli je ustawię, gdy mam do nich bezpośredni dostęp, działa:console.log(appointment.test);

Co zrobiłem źle w tym kodzie?

var appointment = {
    subscribed: false,
    enoughAssis: false,
    studentSlotsOpen: false
};
console.log(appointment);
for (var key in appointmentsDB[i]) {
    appointment[key] = appointmentsDB[i][key];    
}

appointment.test= "res";

console.log(appointment.test);
console.log(appointment);

Oto produkowana produkcja:

{ subscribed: false,
  enoughAssis: false,
  studentSlotsOpen: false }
res
{ comment: 'fsadsf',
  room: 'dqfa',
  reqAssi: 3,
  maxStud: 20,
  timeSlot: 8,
  week: 31,
  year: 2013,
  day: 3,
  _id: 51f957e1200cb0803f000001,
  students: [],
  assis: [] }

Zmiennaconsole.log(appointmentsDB[i]) wygląda jak:

{ comment: 'fsadsf',
  room: 'dqfa',
  reqAssi: 3,
  maxStud: 20,
  timeSlot: 8,
  week: 31,
  year: 2013,
  day: 3,
  _id: 51f957e1200cb0803f000001,
  students: [],
  assis: [] }

Następujące polecenie:

console.log(Object.getOwnPropertyNames(appointmentsDB[i]), Object.getOwnPropertyNames(Object.getPrototypeOf(appointmentsDB[i])));

Przedstawia:

[ '_activePaths',
  '_events',
  'errors',
  '_maxListeners',
  '_selected',
  '_saveError',
  '_posts',
  'save',
  '_pres',
  '_validationError',
  '_strictMode',
  'isNew',
  '_doc',
  '_shardval' ] [ 'assis',
  'timeSlot',
  'db',
  '_schema',
  'id',
  'base',
  'day',
  'collection',
  'reqAssi',
  'constructor',
  'comment',
  'year',
  'room',
  'students',
  'week',
  '_id',
  'maxStud' ]

Spodziewałbym się jednak, że moje ostatnie wyjście zawiera również test wpisów, subskrybowany, wystarczającyAssis i studentSlotsOpen. Co jest nie tak w tym kodzie?

Rozwiązaniem, które znalazłem, było ręczne skopiowanie elementów, które chciałem.

questionAnswers(1)

yourAnswerToTheQuestion