Для Sikulix App.close() на Mac закрывает приложение, но возвращает false. Это правильно?

Я строю скрипт автоматизации SikuliX на Java и не понимаю, как .close() метод. Внутри Сикули App класс, метод close выглядит следующим образом:

  /**
   * tries to close the app defined by this App instance, waits max given seconds for the app to no longer be running
   *
   * @return this or null on failure
   */
  public boolean close(int waitTime) {
    if (!isRunning()) {
      log("App.close: not running: %s", this);
      return false;
    }
    if (_osUtil.close(this)) {
      int timeTowait = maxWait;
      if (waitTime > 0) {
        timeTowait = waitTime;
      }
      while (isRunning(0) && timeTowait > 0) {
        timeTowait--;
      }
    }
    if (!isValid()) {
      log("App.close: %s", this);
    } else {
      log("App.close: did not work: %s", this);
      return true;
    }
    return false;
  }

Речь идет о возвращении. Насколько я понимаю, поскольку он возвращает логическое значение, оно будет истинным, если закрытие было успешным, и ложным, если закрытие завершилось неудачно. Однако этот код делает противоположное. Исходя из моего ошибочного (?) Понимания этой логики, я изначально написал свой код так,

if (myApp.close()) {
    System.out.println("closed.");
    isAppClosed = true;
} else {
    System.out.println("NOT closed!");
    isAppClosed = false;
}

Это имеет противоположный результат того, что я хочу, так как приложение успешно закрывается, НО тест не пройден, потому что печатается "НЕ закрыто".

Я нашел ошибку, или я что-то упустил?

Благодарю.

1 ответ

Решение

Оказывается, это была ошибка. Сопровождающий проекта исправил проблему в последней сборке 1.1.4. https://bugs.launchpad.net/sikuli/+bug/1811938

Другие вопросы по тегам