diff --git a/lib/src/Room.dart b/lib/src/Room.dart index a05e161..93bf366 100644 --- a/lib/src/Room.dart +++ b/lib/src/Room.dart @@ -106,7 +106,7 @@ class Room { this.avatar, this.notificationCount, this.highlightCount, - this.prev_batch, + this.prev_batch = "", this.draft, this.unread, this.fullyRead, @@ -295,8 +295,8 @@ class Room { Future requestHistory({int historyCount = 100}) async { final dynamic resp = await client.connection.jsonRequest( type: "GET", - action: "/client/r0/rooms/$id/messages", - data: {"from": prev_batch, "dir": "b", "limit": historyCount}); + action: + "/client/r0/rooms/$id/messages?from=${prev_batch}&dir=b&limit=$historyCount"); if (resp is ErrorResponse) return; diff --git a/test/FakeMatrixApi.dart b/test/FakeMatrixApi.dart index cd6b1e7..36b438d 100644 --- a/test/FakeMatrixApi.dart +++ b/test/FakeMatrixApi.dart @@ -31,8 +31,11 @@ class FakeMatrixApi extends MockClient { FakeMatrixApi() : super((request) async { // Collect data from Request - final String action = request.url.path.split("/_matrix")[1]; + String action = + request.url.path.split("/_matrix")[1] + "?" + request.url.query; + if (action.endsWith("?")) action = action.replaceAll("?", ""); final String method = request.method; + print("Got action: $action"); final dynamic data = method == "GET" ? request.url.queryParameters : request.body; var res = {}; @@ -76,64 +79,65 @@ class FakeMatrixApi extends MockClient { "origin_server_ts": 1432735824653, "unsigned": {"age": 1234} }, - "/client/r0/rooms/!1234:example.com/messages": (var req) => { - "start": "t47429-4392820_219380_26003_2265", - "end": "t47409-4357353_219380_26003_2265", - "chunk": [ - { - "content": { - "body": "This is an example text message", - "msgtype": "m.text", - "format": "org.matrix.custom.html", - "formatted_body": "This is an example text message" - }, - "type": "m.room.message", - "event_id": "3143273582443PhrSn:example.org", - "room_id": "!1234:example.com", - "sender": "@example:example.org", - "origin_server_ts": 1432735824653, - "unsigned": {"age": 1234} - }, - { - "content": {"name": "The room name"}, - "type": "m.room.name", - "event_id": "2143273582443PhrSn:example.org", - "room_id": "!1234:example.com", - "sender": "@example:example.org", - "origin_server_ts": 1432735824653, - "unsigned": {"age": 1234}, - "state_key": "" - }, - { - "content": { - "body": "Gangnam Style", - "url": "mxc://example.org/a526eYUSFFxlgbQYZmo442", - "info": { - "thumbnail_url": - "mxc://example.org/FHyPlCeYUSFFxlgbQYZmoEoe", - "thumbnail_info": { - "mimetype": "image/jpeg", - "size": 46144, - "w": 300, - "h": 300 + "/client/r0/rooms/!1234:example.com/messages?from=1234&dir=b&limit=100": + (var req) => { + "start": "t47429-4392820_219380_26003_2265", + "end": "t47409-4357353_219380_26003_2265", + "chunk": [ + { + "content": { + "body": "This is an example text message", + "msgtype": "m.text", + "format": "org.matrix.custom.html", + "formatted_body": "This is an example text message" }, - "w": 480, - "h": 320, - "duration": 2140786, - "size": 1563685, - "mimetype": "video/mp4" + "type": "m.room.message", + "event_id": "3143273582443PhrSn:example.org", + "room_id": "!1234:example.com", + "sender": "@example:example.org", + "origin_server_ts": 1432735824653, + "unsigned": {"age": 1234} }, - "msgtype": "m.video" - }, - "type": "m.room.message", - "event_id": "1143273582443PhrSn:example.org", - "room_id": "!1234:example.com", - "sender": "@example:example.org", - "origin_server_ts": 1432735824653, - "unsigned": {"age": 1234} - } - ] - }, + { + "content": {"name": "The room name"}, + "type": "m.room.name", + "event_id": "2143273582443PhrSn:example.org", + "room_id": "!1234:example.com", + "sender": "@example:example.org", + "origin_server_ts": 1432735824653, + "unsigned": {"age": 1234}, + "state_key": "" + }, + { + "content": { + "body": "Gangnam Style", + "url": "mxc://example.org/a526eYUSFFxlgbQYZmo442", + "info": { + "thumbnail_url": + "mxc://example.org/FHyPlCeYUSFFxlgbQYZmoEoe", + "thumbnail_info": { + "mimetype": "image/jpeg", + "size": 46144, + "w": 300, + "h": 300 + }, + "w": 480, + "h": 320, + "duration": 2140786, + "size": 1563685, + "mimetype": "video/mp4" + }, + "msgtype": "m.video" + }, + "type": "m.room.message", + "event_id": "1143273582443PhrSn:example.org", + "room_id": "!1234:example.com", + "sender": "@example:example.org", + "origin_server_ts": 1432735824653, + "unsigned": {"age": 1234} + } + ] + }, "/client/versions": (var req) => { "versions": ["r0.0.1", "r0.1.0", "r0.2.0", "r0.3.0", "r0.4.0"], "unstable_features": {"m.lazy_load_members": true}, diff --git a/test/Timeline_test.dart b/test/Timeline_test.dart index b66ed69..0af61dd 100644 --- a/test/Timeline_test.dart +++ b/test/Timeline_test.dart @@ -41,7 +41,7 @@ void main() { client.connection.httpClient = FakeMatrixApi(); client.homeserver = "https://fakeServer.notExisting"; - Room room = Room(id: roomID, client: client); + Room room = Room(id: roomID, client: client, prev_batch: "1234"); Timeline timeline = Timeline( room: room, events: [],