Ожидается, что он будет работать в потоке пользовательского интерфейса. - PullRequest
0 голосов
/ 24 апреля 2018

Я пытаюсь синхронизировать захват данных в автономном режиме с онлайн-API, я периодически запускаю фоновую задачу, используя response-native-background-task для извлечения автономных данных и синхронизации данных с онлайн-API.

Ошибка реакции-нативного фонового задания

// This component below triggers the background task on load 

import { sync, clean } from "../../services/market/forms/tasks";
import MediaWorker from "../../services/market/forms/MediaWorker";

let worker = new MediaWorker();

BackgroundTask.define(async () => {
  console.log("Life's good");
  
  // loads data from db and sync them with the online service
  await sync(worker);
  
  // delete synced data from the db and end task
  await clean();
});

export default class Onboard extends Component {
  constructor(props) {
    super(props);
  }

  async checkStatus() {
    const status = await BackgroundTask.statusAsync();

    if (status.available) {
      // schedule the background task
      BackgroundTask.schedule();
      return;
    }

    const reason = status.unavailableReason;
    if (reason === BackgroundTask.UNAVAILABLE_DENIED) {
      Alert.alert(
        "Denied",
        'Please enable background "Background App Refresh" for this app'
      );
    } else if (reason === BackgroundTask.UNAVAILABLE_RESTRICTED) {
      Alert.alert(
        "Restricted",
        "Background tasks are restricted on your device"
      );
    }
  }

  componentDidMount() {
    this.checkStatus();
  }

  render() {
   // Not important for the question
  }
}

// snippet for sync function
export const sync = async worker => {
  const formInstances = await loadFormInstance();

  if (formInstances.length) {
    // Send Textual data
    const formInstancesText = filterFormInstances(formInstances, "text");
    postFormTextInstance(formInstancesText);

    // Get form image data and post
    const formInstancesImage = filterFormInstances(formInstances, "image");
    formInstancesImage.forEach(worker.send);
    // Get form audio data and post

    const formInstancesAudio = filterFormInstances(formInstances, "audio");
    formInstancesAudio.forEach(worker.send);

    // Get form video data and post
    const formInstancesVideo = filterFormInstances(formInstances, "video");
    formInstancesVideo.forEach(worker.send);
  } else {
    console.log("Nothing to sync");
    BackgroundTask.finish();
  }
};


// snippet for clean function
export const clean = async () => {
  const formInstances = await loadFormInstance();
  if (formInstances.length) {
    const toBeDeleted = new Set();
    formInstances.forEach(formInstance => {
      const fields = formInstance.fields;
      let allSynced = true;
      for (let index in fields) {
        const field = fields[index];
        if (field.synced === false) {
          allSynced = false;
          break;
        }
      }
      if (allSynced) {
        toBeDeleted.add(formInstance.instanceID);
      }
    });

    toBeDeleted.forEach(deleteFormInstance);
  } else {
    console.log("All tasks finished");
    BackgroundTask.finish();
  }
};
Журнал Adb (используется для мониторинга фоновой активности)

Примечание : фоновая задача выполняется успешно много раз, но иногда дает сбойс красным экраном, отображаемым при сборке приложения в режиме отладки.В режиме выпуска приложение полностью аварийно завершает работу.

Трассировка стека, созданная Crashlytics в рабочей среде

1 Ответ

0 голосов
/ 25 апреля 2018

Я исправил это, оказалось, что версия реакции-нативной фоновой задачи несовместима с моей версией реакции-нативной, я обновил версию с 0.48.1 до 0.51.0, для которой требуется реакция 16.0.0

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