Как я могу проверить, как мобильное приложение становится приоритетным? - PullRequest
0 голосов
/ 04 июня 2018

У меня есть create-react-native-app, и мне нужно написать тест, чтобы предотвратить регрессию проблемы, когда пользователи возвращают приложение на передний план (кажется, возникают трудности с повторным подключением соединения socket.io).

В настоящее время я должен вручную проверить это, выполнив несколько шагов:

  1. Открыть приложение
  2. Войти в систему
  3. Дождаться завершения входа в систему
  4. Переключение на другое приложение (фоновое изображение)
  5. Подождите, пока фоновое приложение потеряет соединение с сервером (~ 20 секунд)
  6. Повторно откройте приложение (на переднем плане)
  7. Проверьте, возникает ли проблема

Как мне написать автоматические тесты для этого?Я использую jest для модульного тестирования в приложении.

1 Ответ

0 голосов
/ 04 июня 2018

Основное использование

Чтобы увидеть текущее состояние, вы можете проверить AppState.currentState, который будет обновляться.Однако currentState при запуске будет иметь значение null, а AppState получит его по мосту.

import React, {Component} from 'react'
import {AppState, Text} from 'react-native'

class AppStateExample extends Component {

  state = {
    appState: AppState.currentState
  }

  componentDidMount() {
    AppState.addEventListener('change', this._handleAppStateChange);
  }

  componentWillUnmount() {
    AppState.removeEventListener('change', this._handleAppStateChange);
  }

  _handleAppStateChange = (nextAppState) => {
    if (this.state.appState.match(/inactive|background/) && nextAppState === 'active') {
      console.log('App has come to the foreground!')
    }
    this.setState({appState: nextAppState});
  }

  render() {
    return (
      <Text>Current state is: {this.state.appState}</Text>
    );
  }

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