summaryrefslogtreecommitdiff
path: root/test/UnitStorage.cpp
blob: 91b08ec9ff41308579cd01563d760c91c5994e9a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 */

#include <config.h>

#include <iostream>

#include <Exceptions.hpp>
#include <Log.hpp>
#include <Unit.hpp>
#include <UnitHTTP.hpp>
#include <helpers.hpp>

using namespace helpers;

class UnitStorage : public UnitWSD
{
    enum class Phase {
        Load,             // load the document
        Filter,           // throw filter exception
        Reload,           // re-load the document
    } _phase;
    std::unique_ptr<UnitWebSocket> _ws;
public:
    UnitStorage() :
        _phase(Phase::Load)
    {
    }

    bool filterCheckDiskSpace(const std::string & /* path */,
                              bool &newResult) override
    {
        newResult = _phase != Phase::Filter;
        return true;
    }

    void loadDocument(bool bExpectFailure)
    {
        std::string docPath;
        std::string docURL;
        getDocumentPathAndURL("empty.odt", docPath, docURL, "unitStorage ");
        _ws = std::unique_ptr<UnitWebSocket>(new UnitWebSocket(docURL));
        assert(_ws.get());
        int flags = 0, len;;
        char reply[4096];
        while ((len = _ws->getLOOLWebSocket()->receiveFrame(reply, sizeof(reply) - 1, flags)) > 0)
        {
            reply[len] = '\0';
            if (bExpectFailure &&
                !strcmp(reply, "error: cmd=internal kind=diskfull"))
            {
                LOG_TRC("Got expected load failure error");
                _phase = Phase::Reload;
                break;
            }
            else if (!bExpectFailure &&
                     !strncmp(reply, "status: ", sizeof("status: ") - 1))
            {
                LOG_TRC("Load completed as expected");
                break;
            }
            else
                std::cerr << "reply '" << reply << "'\n";
        }
    }

    void invokeTest() override
    {
        LOG_TRC("invokeTest: " << (int)_phase);
        switch (_phase)
        {
        case Phase::Load:
            _phase = Phase::Filter;
            loadDocument(true);
            break;
        case Phase::Filter:
            break;
        case Phase::Reload:
            loadDocument(false);
            _ws.reset();
            exitTest(TestResult::Ok);
            break;
        }
    }
};

UnitBase *unit_create_wsd(void)
{
    return new UnitStorage();
}

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */