/*
    KWin - the KDE window manager
    This file is part of the KDE project.

    SPDX-FileCopyrightText: 2021 David Edmundson <davidedmundson@kde.org>

    SPDX-License-Identifier: LGPL-2.0-or-later
*/

#include <QObject>
#include <QTemporaryFile>
#include <QTest>

#include "ftrace.h"

class TestFTrace : public QObject
{
    Q_OBJECT
public:
    TestFTrace();
private Q_SLOTS:
    void benchmarkTraceOff();
    void benchmarkTraceDurationOff();
    void enable();

private:
    QTemporaryFile m_tempFile;
};

TestFTrace::TestFTrace()
{
    m_tempFile.open();
    qputenv("KWIN_PERF_FTRACE_FILE", m_tempFile.fileName().toLatin1());

    KWin::FTraceLogger::create();
}

void TestFTrace::benchmarkTraceOff()
{
    // this macro should no-op, so take no time at all
    QBENCHMARK {
        fTrace("BENCH", 123, "foo");
    }
}

void TestFTrace::benchmarkTraceDurationOff()
{
    QBENCHMARK {
        fTraceDuration("BENCH", 123, "foo");
    }
}

void TestFTrace::enable()
{
    KWin::FTraceLogger::self()->setEnabled(true);
    QVERIFY(KWin::FTraceLogger::self()->isEnabled());

    {
        fTrace("TEST", 123, "foo");
        fTraceDuration("TEST_DURATION", "boo");
        fTrace("TEST", 123, "foo");
    }

    QCOMPARE(m_tempFile.readLine(), "TEST123foo\n");
    QCOMPARE(m_tempFile.readLine(), "TEST_DURATIONboo begin_ctx=1\n");
    QCOMPARE(m_tempFile.readLine(), "TEST123foo\n");
    QCOMPARE(m_tempFile.readLine(), "TEST_DURATIONboo end_ctx=1\n");
}

QTEST_MAIN(TestFTrace)

#include "test_ftrace.moc"