xaizek / dit (License: GPLv3) (since 2018-12-07)
Command-line task keeper that remembers all old values and is meant to combine several orthogonal features to be rather flexible in managing items.
<root> / tests / ItemTable.cpp (b7c0859cdf2983c3a21b73b7047e58e7635dcad4) (2,490B) (mode 100644) [raw]
// Copyright (C) 2015 xaizek <xaizek@openmailbox.org>
//
// This file is part of dit.
//
// dit is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// dit is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with dit.  If not, see <http://www.gnu.org/licenses/>.

#include "Catch/catch.hpp"

#include <sstream>
#include <string>

#include "Change.hpp"
#include "Item.hpp"
#include "ItemTable.hpp"

#include "Tests.hpp"

TEST_CASE("No columns result in no output.", "[item-table][format]")
{
    Item item = Tests::makeItem("id");
    item.setValue("title", "title");

    ItemTable table(std::string(), std::string(), std::string(), 80);
    table.append(item);

    std::ostringstream oss;
    table.print(oss);

    REQUIRE(oss.str() == std::string());
}

TEST_CASE("Longer column gets shortened first.", "[item-table][sizing]")
{
    Item item = Tests::makeItem("id");
    item.setValue("title", "title");

    ItemTable table("_id,title", std::string(), std::string(), 8);
    table.append(item);

    std::ostringstream oss;
    table.print(oss);

    const std::string expected = "ID  T...\n"
                                 "id  t...\n";
    REQUIRE(oss.str() == expected);
}

TEST_CASE("Zero terminal size results in no output.", "[item-table][sizing]")
{
    Item item = Tests::makeItem("id");
    item.setValue("title", "title");

    ItemTable table("_id,title", std::string(), std::string(), 0);
    table.append(item);

    std::ostringstream oss;
    table.print(oss);

    REQUIRE(oss.str() == std::string());
}

TEST_CASE("Sorting is performed.", "[item-table][sorting]")
{
    Item itemA = Tests::makeItem("aaa");
    Item itemB = Tests::makeItem("bbb");
    Item itemC = Tests::makeItem("ccc");

    ItemTable table("_id", std::string(), std::string("_id"), 80);
    table.append(itemC);
    table.append(itemA);
    table.append(itemB);

    std::ostringstream oss;
    table.print(oss);

    const std::string expected =
        "ID \n"
        "aaa\n"
        "bbb\n"
        "ccc\n";
    REQUIRE(oss.str() == expected);
}
Hints

Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://code.reversed.top/user/xaizek/dit

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@code.reversed.top/user/xaizek/dit

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a pull request:
... clone the repository ...
... make some changes and some commits ...
git push origin master