fix: fixed test.calendarwebapp.jsonexport

This commit is contained in:
Johannes Loher 2018-01-14 18:33:29 +01:00
parent 3b650cb638
commit 39d1626ef7
2 changed files with 37 additions and 14 deletions

View file

@ -93,8 +93,8 @@ class AppArgumentsInjector : ValueInjector!Arguments
{ {
private: private:
Arguments arguments; Arguments arguments;
public:
public:
this() this()
{ {
import vibe.core.args : readOption; import vibe.core.args : readOption;
@ -111,8 +111,7 @@ public:
"The password to use for logging into the MySQL instance."); "The password to use for logging into the MySQL instance.");
readOption("mysql.database", &arguments.mysql.database, readOption("mysql.database", &arguments.mysql.database,
"The name of the MySQL database to use."); "The name of the MySQL database to use.");
readOption("output", &arguments.output, readOption("output", &arguments.output, "The file to write JSON output to.");
"The file to write JSON output to.");
} }
override Arguments get(string key) @safe override Arguments get(string key) @safe
@ -124,6 +123,18 @@ public:
} }
} }
class StubAppArgumentsInjector : ValueInjector!Arguments
{
public:
override Arguments get(string key) @safe
{
import std.exception : enforce;
enforce(key == "", "There is only one instance of Arguments, to inject it use @Value().");
return Arguments.init;
}
}
enum DatabaseArgument enum DatabaseArgument
{ {
mongodb, mongodb,

View file

@ -1,5 +1,6 @@
module test.calendarwebapp.testjsonexport; module test.calendarwebapp.testjsonexport;
import calendarwebapp.configuration: Arguments, StubAppArgumentsInjector;
import calendarwebapp.event; import calendarwebapp.event;
import calendarwebapp.jsonexport; import calendarwebapp.jsonexport;
@ -22,6 +23,7 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
exporter.write.each!(dayData => dayData.events.empty.shouldBeTrue); exporter.write.each!(dayData => dayData.events.empty.shouldBeTrue);
} }
@ -32,6 +34,7 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
auto eventStore = container.resolve!EventStore; auto eventStore = container.resolve!EventStore;
immutable event = Event("599090de97355141140fc698", Date(2018, 1, 14)); immutable event = Event("599090de97355141140fc698", Date(2018, 1, 14));
@ -47,6 +50,7 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
auto eventStore = container.resolve!EventStore; auto eventStore = container.resolve!EventStore;
immutable event1 = Event("599090de97355141140fc698", Date(2018, 1, 14)); immutable event1 = Event("599090de97355141140fc698", Date(2018, 1, 14));
@ -64,6 +68,7 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
auto eventStore = container.resolve!EventStore; auto eventStore = container.resolve!EventStore;
immutable event1 = Event("599090de97355141140fc698", Date(2018, 1, 14)); immutable event1 = Event("599090de97355141140fc698", Date(2018, 1, 14));
@ -93,8 +98,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2018, Month.jan, "Januar", 14, DayType.Holiday, [], "Sonntag", []).shouldBeIn( DayData(2018, Month.jan, "Januar", 14, DayType.Holiday, [], "So", []).shouldBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -104,8 +110,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2018, Month.jan, "Januar", 1, DayType.Workday, [], "Montag", []).shouldBeIn( DayData(2018, Month.jan, "Januar", 1, DayType.Workday, [], "Mo", []).shouldBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -115,8 +122,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2018, Month.jan, "Januar", 2, DayType.Workday, [], "Dienstag", []).shouldBeIn( DayData(2018, Month.jan, "Januar", 2, DayType.Workday, [], "Di", []).shouldBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -126,8 +134,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2017, Month.dec, "Dezember", 1, DayType.Holiday, [], "Sonntag", []).shouldNotBeIn( DayData(2017, Month.dec, "Dezember", 1, DayType.Holiday, [], "So", []).shouldNotBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -137,8 +146,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2018, Month.mar, "März", 31, DayType.Weekend, [], "Samstag", []).shouldBeIn( DayData(2018, Month.mar, "März", 31, DayType.Weekend, [], "Sa", []).shouldBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -148,8 +158,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2018, Month.mar, "März", 30, DayType.Workday, [], "Freitag", []).shouldBeIn( DayData(2018, Month.mar, "März", 30, DayType.Workday, [], "Fr", []).shouldBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -159,8 +170,9 @@ import unit_threaded;
auto container = new shared DependencyContainer(); auto container = new shared DependencyContainer();
container.register!(EventStore, StubEventStore); container.register!(EventStore, StubEventStore);
container.register!JSONExporter; container.register!JSONExporter;
container.register!(ValueInjector!Arguments, StubAppArgumentsInjector);
auto exporter = container.resolve!JSONExporter; auto exporter = container.resolve!JSONExporter;
DayData(2018, Month.apr, "April", 1, DayType.Holiday, [], "Sonntag", []).shouldNotBeIn( DayData(2018, Month.apr, "April", 1, DayType.Holiday, [], "So", []).shouldNotBeIn(
exporter.write(Date(2018, 1, 14))); exporter.write(Date(2018, 1, 14)));
} }
@ -202,7 +214,7 @@ import unit_threaded;
{ {
auto dayDataManager = DayDataManager(Date(2018, 1, 14), Date(2018, 1, 16)); auto dayDataManager = DayDataManager(Date(2018, 1, 14), Date(2018, 1, 16));
dayDataManager.getDayData(Date(2018, 1, 14)).shouldEqual(DayData(2018, dayDataManager.getDayData(Date(2018, 1, 14)).shouldEqual(DayData(2018,
Month.jan, "Januar", 14, DayType.Holiday, [], "Sonntag", [])); Month.jan, "Januar", 14, DayType.Holiday, [], "So", []));
} }
@("DayDataManager.getDayData with begin < date < end and 0 events") @("DayDataManager.getDayData with begin < date < end and 0 events")
@ -210,7 +222,7 @@ import unit_threaded;
{ {
auto dayDataManager = DayDataManager(Date(2018, 1, 14), Date(2018, 1, 16)); auto dayDataManager = DayDataManager(Date(2018, 1, 14), Date(2018, 1, 16));
dayDataManager.getDayData(Date(2018, 1, 15)).shouldEqual(DayData(2018, dayDataManager.getDayData(Date(2018, 1, 15)).shouldEqual(DayData(2018,
Month.jan, "Januar", 15, DayType.Workday, [], "Montag", [])); Month.jan, "Januar", 15, DayType.Workday, [], "Mo", []));
} }
@("DayDataManager.getDayData with date < begin and 1 event") @("DayDataManager.getDayData with date < begin and 1 event")
@ -247,7 +259,7 @@ import unit_threaded;
immutable event = Event("599090de97355141140fc698", Date(2018, 1, 14)); immutable event = Event("599090de97355141140fc698", Date(2018, 1, 14));
dayDataManager.addEvent(event); dayDataManager.addEvent(event);
dayDataManager.getDayData(Date(2018, 1, 14)).shouldEqual(DayData(2018, dayDataManager.getDayData(Date(2018, 1, 14)).shouldEqual(DayData(2018,
Month.jan, "Januar", 14, DayType.Holiday, [event], "Sonntag", [])); Month.jan, "Januar", 14, DayType.Holiday, [event], "So", []));
} }
@("DayDataManager.getDayData with begin < date < end and 1 event") @("DayDataManager.getDayData with begin < date < end and 1 event")
@ -257,5 +269,5 @@ import unit_threaded;
immutable event = Event("599090de97355141140fc698", Date(2018, 1, 15)); immutable event = Event("599090de97355141140fc698", Date(2018, 1, 15));
dayDataManager.addEvent(event); dayDataManager.addEvent(event);
dayDataManager.getDayData(Date(2018, 1, 15)).shouldEqual(DayData(2018, dayDataManager.getDayData(Date(2018, 1, 15)).shouldEqual(DayData(2018,
Month.jan, "Januar", 15, DayType.Workday, [event], "Montag", [])); Month.jan, "Januar", 15, DayType.Workday, [event], "Mo", []));
} }