mirror of
https://github.com/moodle/moodle.git
synced 2025-08-08 02:16:41 +02:00
MDL-63691 core_message: added api::create_conversation
This commit is contained in:
parent
e66b915c40
commit
f2ac0a3e5b
7 changed files with 186 additions and 16 deletions
|
@ -2127,6 +2127,7 @@ class core_message_api_testcase extends core_message_messagelib_testcase {
|
|||
$user2 = self::getDataGenerator()->create_user();
|
||||
|
||||
$conversationid = \core_message\api::create_conversation_between_users([$user1->id, $user2->id]);
|
||||
$this->assertDebuggingCalled();
|
||||
|
||||
$this->assertEquals($conversationid,
|
||||
\core_message\api::get_conversation_between_users([$user1->id, $user2->id]));
|
||||
|
@ -2398,7 +2399,14 @@ class core_message_api_testcase extends core_message_messagelib_testcase {
|
|||
$user1 = self::getDataGenerator()->create_user();
|
||||
$user2 = self::getDataGenerator()->create_user();
|
||||
|
||||
$conversationid = \core_message\api::create_conversation_between_users([$user1->id, $user2->id]);
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL,
|
||||
[
|
||||
$user1->id,
|
||||
$user2->id
|
||||
]
|
||||
);
|
||||
$conversationid = $conversation->id;
|
||||
|
||||
$this->assertTrue(\core_message\api::is_user_in_conversation($user1->id, $conversationid));
|
||||
}
|
||||
|
@ -2411,7 +2419,14 @@ class core_message_api_testcase extends core_message_messagelib_testcase {
|
|||
$user2 = self::getDataGenerator()->create_user();
|
||||
$user3 = self::getDataGenerator()->create_user();
|
||||
|
||||
$conversationid = \core_message\api::create_conversation_between_users([$user1->id, $user2->id]);
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL,
|
||||
[
|
||||
$user1->id,
|
||||
$user2->id
|
||||
]
|
||||
);
|
||||
$conversationid = $conversation->id;
|
||||
|
||||
$this->assertFalse(\core_message\api::is_user_in_conversation($user3->id, $conversationid));
|
||||
}
|
||||
|
@ -2445,6 +2460,84 @@ class core_message_api_testcase extends core_message_messagelib_testcase {
|
|||
$this->assertTrue(\core_message\api::can_create_group_conversation($teacher->id, $coursecontext));
|
||||
}
|
||||
|
||||
/**
|
||||
* Test creating an individual conversation.
|
||||
*/
|
||||
public function test_create_conversation_individual() {
|
||||
$user1 = self::getDataGenerator()->create_user();
|
||||
$user2 = self::getDataGenerator()->create_user();
|
||||
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL,
|
||||
[
|
||||
$user1->id,
|
||||
$user2->id
|
||||
],
|
||||
'A conversation name'
|
||||
);
|
||||
|
||||
$this->assertEquals(\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL, $conversation->type);
|
||||
$this->assertEquals('A conversation name', $conversation->name);
|
||||
$this->assertEquals(\core_message\helper::get_conversation_hash([$user1->id, $user2->id]), $conversation->convhash);
|
||||
|
||||
$this->assertCount(2, $conversation->members);
|
||||
|
||||
$member1 = array_shift($conversation->members);
|
||||
$member2 = array_shift($conversation->members);
|
||||
|
||||
$this->assertEquals($user1->id, $member1->userid);
|
||||
$this->assertEquals($conversation->id, $member1->conversationid);
|
||||
|
||||
$this->assertEquals($user2->id, $member2->userid);
|
||||
$this->assertEquals($conversation->id, $member2->conversationid);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test creating a group conversation.
|
||||
*/
|
||||
public function test_create_conversation_group() {
|
||||
$user1 = self::getDataGenerator()->create_user();
|
||||
$user2 = self::getDataGenerator()->create_user();
|
||||
$user3 = self::getDataGenerator()->create_user();
|
||||
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_GROUP,
|
||||
[
|
||||
$user1->id,
|
||||
$user2->id,
|
||||
$user3->id
|
||||
],
|
||||
'A conversation name'
|
||||
);
|
||||
|
||||
$this->assertEquals(\core_message\api::MESSAGE_CONVERSATION_TYPE_GROUP, $conversation->type);
|
||||
$this->assertEquals('A conversation name', $conversation->name);
|
||||
$this->assertNull($conversation->convhash);
|
||||
|
||||
$this->assertCount(3, $conversation->members);
|
||||
|
||||
$member1 = array_shift($conversation->members);
|
||||
$member2 = array_shift($conversation->members);
|
||||
$member3 = array_shift($conversation->members);
|
||||
|
||||
$this->assertEquals($user1->id, $member1->userid);
|
||||
$this->assertEquals($conversation->id, $member1->conversationid);
|
||||
|
||||
$this->assertEquals($user2->id, $member2->userid);
|
||||
$this->assertEquals($conversation->id, $member2->conversationid);
|
||||
|
||||
$this->assertEquals($user3->id, $member3->userid);
|
||||
$this->assertEquals($conversation->id, $member3->conversationid);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test creating an individual conversation with too many members.
|
||||
*/
|
||||
public function test_create_conversation_individual_too_many_members() {
|
||||
$this->expectException('moodle_exception');
|
||||
\core_message\api::create_conversation(\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL, [1, 2, 3]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Comparison function for sorting contacts.
|
||||
*
|
||||
|
|
|
@ -74,8 +74,14 @@ class core_message_externallib_testcase extends externallib_advanced_testcase {
|
|||
}
|
||||
|
||||
if (!$conversationid = \core_message\api::get_conversation_between_users([$userfrom->id, $userto->id])) {
|
||||
$conversationid = \core_message\api::create_conversation_between_users([$userfrom->id,
|
||||
$userto->id]);
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL,
|
||||
[
|
||||
$userfrom->id,
|
||||
$userto->id
|
||||
]
|
||||
);
|
||||
$conversationid = $conversation->id;
|
||||
}
|
||||
|
||||
// Ok, send the message.
|
||||
|
|
|
@ -86,8 +86,14 @@ class core_message_messagelib_testcase extends advanced_testcase {
|
|||
}
|
||||
|
||||
if (!$conversationid = \core_message\api::get_conversation_between_users([$userfrom->id, $userto->id])) {
|
||||
$conversationid = \core_message\api::create_conversation_between_users([$userfrom->id,
|
||||
$userto->id]);
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL,
|
||||
[
|
||||
$userfrom->id,
|
||||
$userto->id
|
||||
]
|
||||
);
|
||||
$conversationid = $conversation->id;
|
||||
}
|
||||
|
||||
// Ok, send the message.
|
||||
|
|
|
@ -663,8 +663,14 @@ class core_message_privacy_provider_testcase extends \core_privacy\tests\provide
|
|||
}
|
||||
|
||||
if (!$conversationid = \core_message\api::get_conversation_between_users([$useridfrom, $useridto])) {
|
||||
$conversationid = \core_message\api::create_conversation_between_users([$useridfrom,
|
||||
$useridto]);
|
||||
$conversation = \core_message\api::create_conversation(
|
||||
\core_message\api::MESSAGE_CONVERSATION_TYPE_INDIVIDUAL,
|
||||
[
|
||||
$useridfrom,
|
||||
$useridto
|
||||
]
|
||||
);
|
||||
$conversationid = $conversation->id;
|
||||
}
|
||||
|
||||
// Ok, send the message.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue