Ошибка BlazeDS при выполнении тестов Flexunit: обнаружены дублированные FlexSessions на основе HTTP - PullRequest
0 голосов
/ 26 октября 2010

Я использую плагин Maven Flexmojos для запуска некоторых интеграционных тестов FlexUnit4 в командной строке с бэкэндом Jetty / Java / Spring Security / BlazeDS. Эти интеграционные тесты выполняются в автономной версии флэш-плеера. Один из этих тестов пытается выполнить несколько различных сценариев входа в систему следующим образом:

    [Test(async)]   
    public function userLogin_badCredentials_FailedLogin():void {
        var username:String = "guest";
        var password:String = "not_the_right_password";

        var token:AsyncToken = authenticationService.userLogin(username, password);
        token.addResponder(Async.asyncResponder(this, new TestResponder(handleRemoteObjectNoExpectedResult, handleRemoteObjectExpectedFaultBadCredentials), TIMEOUT, username, handleTestTimeout));
    }


    [Test(async)]
    public function userLoginLogout_UserLoggedIn_SuccessfulLoginLogout():void {
        var username:String = "admin";
        var password:String = "admin";

        var token:AsyncToken = authenticationService.userLogin(username, password);;
        token.addResponder(Async.asyncResponder(this, new TestResponder(userLoginLogout2_UserLoggedIn_SuccessfulLoginLogout, handleUnexpectedFault), TIMEOUT, username, handleTestTimeout));
    }
    public function userLoginLogout2_UserLoggedIn_SuccessfulLoginLogout(event:ResultEvent, passThroughData:Object):void {
        // Must have logged in correctly
        assertTrue(serviceManager.channelSet.authenticated);

        // Now lets test logout
        var token:AsyncToken = authenticationService.userLogout();
        token.addResponder(Async.asyncResponder(this, new TestResponder(handleExpectedResult, handleUnexpectedFault), TIMEOUT, null, handleTestTimeout));
    }

Любой из этих тестов проходит 100% сам по себе, но, выполняя их оба один за другим, я периодически (примерно в 75% случаев) получаю ошибку:

Channel.Ping.Failed error Detected duplicate HTTP-based FlexSessions, generally
 due to the remote host disabling session cookies. Session cookies must be enabled
 to manage the client connection correctly.

Это также происходит, если я пытаюсь войти / выйти дважды. Все методы входа и выхода основаны на ChannelSet.login и ChannelSet.logout, использующих AMFChannelSet.

Обновление: Мне кажется, я нашел источник проблемы. Автономный плеер не использует куки-файлы и поэтому вводит в заблуждение серверную часть BlazeDS. Смотрите здесь: http://www.webappsolution.com/wordpress/2009/11/25/flexunit-4-testing-services-in-flash-player-issue/

1 Ответ

1 голос
/ 27 октября 2010

Прерывистый характер проблемы привел меня к предположению, что происходило состояние гонки.Используя утилиту отладки протоколов Charles, я мог видеть сообщения запроса / ответа AMF.Я не был (и до сих пор не уверен), но мое лучшее предположение состояло в том, что вторая попытка входа в систему происходила до того, как у сервера была возможность полностью отключить предыдущую FlexSession.

Таким образом, чтобы «выиграть время» междупопытки входа в систему Я разделил тестовые методы на разные тестовые классы и альт ... все это только что сработало.

Возможно, сон / задержка после теста также помогла бы, но я не смог найти ActionScriptфункция сна.

...