Облачные функции Firebase aync / await возвращают неопределенное значение, вызывая сбой функции - PullRequest
0 голосов
/ 02 марта 2019

У меня есть следующая облачная функция firebase:

export const  setFlightAlert = functions.database.ref('/trips/{pushId}/milestones').onCreate(async (snapshot) => {
    let milestones: Milestone[] = [];
    for (let milestone of snapshot.val()) {
        let alert_id = 0;
        if (+milestone.type.key === MilestoneTypes.departed_airport) {
            const request = await setAlertId(milestone);
            alert_id = request;
            milestone = {
                ...milestone,
                alert_id: alert_id,
                ident: milestone.airline.name + milestone.flight_number
            };
        } else if (+milestone.type.key === MilestoneTypes.arrived_airport) {
            milestone = {
                ...milestone,
                alert_id: alert_id,
                ident: milestone.airline.name + milestone.flight_number
            };
        }
        milestones = [...milestones, milestone];
    }
    return snapshot.ref.set(milestones)
})

async function setAlertId(milestone: Milestone) {
    let alert_id;
    const data = new FormData();
    data.append('alert_id', 0);
    data.append('ident', `${milestone.airline.name}${milestone.flight_number}`);
    data.append('origin', milestone.airport.icao);
    data.append('date_start', new Date(milestone.flight_time).getTime() / 1000);
    data.append('date_end', new Date(milestone.flight_time).getTime() / 1000);
    data.append('chennels', '{16 e_filed e_departure e_arrival e_diverted e_cancelled}');
    alert_id = await axios.post<{SetAlertResult: number}>(urls.setAlert, data, {
        headers: {...headers, ...data.getHeaders()},
        withCredentials: true
    })
    return alert_id.data.SetAlertResult;
}

, когда эта функция запускается, она должна получить значение для alert_ad из асинхронного вызова ожидания до setAlertId().Однако, когда это выполняется, я получаю сообщение об ошибке в журнале облачных функций, которое говорит, что оно не определено.Я не уверен, почему это происходит.

Error: Reference.set failed: First argument contains undefined in property 'trips.-LZztKpsQxr_9p3p4-D3.milestones.0.alert_id'
    at validateFirebaseData (/user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:1442:15)
    at /user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:1488:13
    at Object.forEach (/user_code/node_modules/firebase-admin/node_modules/@firebase/util/dist/index.node.cjs.js:846:13)
    at validateFirebaseData (/user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:1471:14)
    at /user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:1488:13
    at Object.forEach (/user_code/node_modules/firebase-admin/node_modules/@firebase/util/dist/index.node.cjs.js:846:13)
    at validateFirebaseData (/user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:1471:14)
    at validateFirebaseDataArg (/user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:1430:5)
    at Reference.set (/user_code/node_modules/firebase-admin/node_modules/@firebase/database/dist/index.node.cjs.js:14026:9)
    at Object.<anonymous> (/user_code/lib/index.js:46:70)

Как мне проверить или зарегистрировать это, чтобы я мог убедиться, что async / await действительно получает значение?

1 Ответ

0 голосов
/ 02 марта 2019

Как и в любой среде JavaScript, вы используете console.log() для регистрации значений.Они будут видны в консоли Firebase.

Также рассмотрите возможность проведения локального тестирования для упрощения тестирования и отладки.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...