console.log não mostrando as propriedades esperadas do objeto

Eu tenho o seguinte código em javascript no meu aplicativo node.js. No entanto, certos objetos não são armazenados na minha variávelappointment. Mesmo se eu configurá-los, quando eu acessá-los diretamente, ele funciona:console.log(appointment.test);

O que eu fiz de errado neste código?

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);

E aqui está a saída produzida:

{ 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: [] }

A variávelconsole.log(appointmentsDB[i]) parece como:

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

O seguinte comando:

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

Shows:

[ '_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' ]

No entanto, eu esperaria que minha última saída também fornecesse o teste de entradas, inscrito, enoughAssis e studentSlotsOpen. O que há de errado nesse código?

A solução que encontrei foi copiar manualmente os elementos que queria.

questionAnswers(1)

yourAnswerToTheQuestion