Skip to content

Commit

Permalink
WIP Shared subscribe with virtdomains
Browse files Browse the repository at this point in the history
  • Loading branch information
elliefm committed Dec 9, 2024
1 parent ad9ba33 commit 9ae5781
Showing 1 changed file with 64 additions and 22 deletions.
86 changes: 64 additions & 22 deletions cassandane/Cassandane/Cyrus/Shared.pm
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ use Data::Dumper;
use lib '.';
use base qw(Cassandane::Cyrus::TestCase);
use Cassandane::Instance;
use Cassandane::Mboxname;
use Cassandane::Util::Log;
use Cassandane::Util::Words;

Expand Down Expand Up @@ -79,51 +80,65 @@ sub shared_subscribe_common
my ($self, $user1, $user2) = @_;

my $service = $self->{instance}->get_service('imap');
my $config = $self->{instance}->{config};
my $sep = $config->get_bool('unixhierarchysep', 'on') ? '/' : '.';

my @user1_mailboxes = random_words(3);
my $user1_inbox = Cassandane::Mboxname->new(config => $config);
$user1_inbox->from_username($user1);

my @user1_mailboxes = map {
$user1_inbox->make_child($_);
} random_words(3);
$self->{instance}->create_user($user1,
subdirs => \@user1_mailboxes);

my $user1_store = $service->create_store(username => $user1);
my $user1_talk = $user1_store->get_client();

foreach my $mb (@user1_mailboxes) {
$user1_talk->subscribe($mb);
$user1_talk->setacl($mb, $user2, 'lrs');
$user1_talk->subscribe($mb->to_external('owner'));
$user1_talk->setacl($mb->to_external('owner'), $user2, 'lrs');
}

my @user2_mailboxes = random_words(3);
my $user2_inbox = Cassandane::Mboxname->new(config => $config);
$user2_inbox->from_username($user2);

my @user2_mailboxes = map {
$user2_inbox->make_child($_);
} random_words(3);
$self->{instance}->create_user($user2,
subdirs => \@user2_mailboxes);

my $user2_store = $service->create_store(username => $user2);
my $user2_talk = $user2_store->get_client();

foreach my $mb (@user2_mailboxes) {
$user2_talk->subscribe($mb);
$user2_talk->setacl($mb, $user1, 'lrs');
$user2_talk->subscribe($mb->to_external('owner'));
$user2_talk->setacl($mb->to_external('owner'), $user1, 'lrs');
}

$user1_talk->list('', '*');

xlog("subscribe as $user1 to $user2\'s shared mb's");
foreach my $mb (@user2_mailboxes) {
$user1_talk->subscribe("Other Users.$user2.$mb");
$user1_talk->subscribe($mb->to_external('other'));
$self->assert_equals('ok', $user1_talk->get_last_completion_response());
}

xlog("but not their inbox");
$user1_talk->subscribe("Other Users.$user2");
$user1_talk->subscribe($user2_inbox->to_external('other'));
$self->assert_equals('no', $user1_talk->get_last_completion_response());

xlog("make sure $user1 has the right subscriptions");
my $user1_subs = $user1_talk->list([qw(SUBSCRIBED)],
'', '*',
'RETURN', [qw(CHILDREN)]);
$self->assert_mailbox_structure($user1_subs, '.', {
$self->assert_mailbox_structure($user1_subs, $sep, {
(map {(
$_ => [ '\\Subscribed', '\\HasNoChildren' ]
$_->to_external('owner') => [ '\\Subscribed', '\\HasNoChildren' ]
)} @user1_mailboxes),
(map {(
"Other Users.$user2.$_" => [
$_->to_external('other') => [
'\\Subscribed',
'\\HasNoChildren',
]
Expand All @@ -132,41 +147,41 @@ sub shared_subscribe_common

xlog("unsub as $user1 from $user2\'s folders");
foreach my $mb (@user2_mailboxes) {
$user1_talk->unsubscribe("Other Users.$user2.$mb");
$user1_talk->unsubscribe($mb->to_external('other'));
$self->assert_equals('ok', $user1_talk->get_last_completion_response());
}

xlog("make sure $user1 has the right subscriptions");
$user1_subs = $user1_talk->list([qw(SUBSCRIBED)],
'', '*',
'RETURN', [qw(CHILDREN)]);
$self->assert_mailbox_structure($user1_subs, '.', {
$self->assert_mailbox_structure($user1_subs, $sep, {
(map {(
$_ => [ '\\Subscribed', '\\HasNoChildren' ]
$_->to_external('owner') => [ '\\Subscribed', '\\HasNoChildren' ]
)} @user1_mailboxes),
});

xlog("subscribe as $user2 to $user1\'s shared mb's");
foreach my $mb (@user1_mailboxes) {
$user2_talk->subscribe("Other Users.$user1.$mb");
$user2_talk->subscribe($mb->to_external('other'));
$self->assert_equals('ok',
$user2_talk->get_last_completion_response());
}

xlog("but not their inbox");
$user2_talk->subscribe("Other Users.$user1");
$user2_talk->subscribe($user1_inbox->to_external('other'));
$self->assert_equals('no', $user2_talk->get_last_completion_response());

xlog("make sure $user2 has the right subscriptions");
my $user2_subs = $user2_talk->list([qw(SUBSCRIBED)],
'', '*',
'RETURN', [qw(CHILDREN)]);
$self->assert_mailbox_structure($user2_subs, '.', {
$self->assert_mailbox_structure($user2_subs, $sep, {
(map {(
$_ => [ '\\Subscribed', '\\HasNoChildren' ]
$_->to_external('owner') => [ '\\Subscribed', '\\HasNoChildren' ]
)} @user2_mailboxes),
(map {(
"Other Users.$user1.$_" => [
$_->to_external('other') => [
'\\Subscribed',
'\\HasNoChildren',
]
Expand All @@ -175,7 +190,7 @@ sub shared_subscribe_common

xlog("unsub as $user2 from $user1\'s folders");
foreach my $mb (@user1_mailboxes) {
$user2_talk->unsubscribe("Other Users.$user1.$mb");
$user2_talk->unsubscribe($mb->to_external('other'));
$self->assert_equals('ok',
$user2_talk->get_last_completion_response());
}
Expand All @@ -184,9 +199,9 @@ sub shared_subscribe_common
$user2_subs = $user2_talk->list([qw(SUBSCRIBED)],
'', '*',
'RETURN', [qw(CHILDREN)]);
$self->assert_mailbox_structure($user2_subs, '.', {
$self->assert_mailbox_structure($user2_subs, $sep, {
(map {(
$_ => [ '\\Subscribed', '\\HasNoChildren' ]
$_->to_external('owner') => [ '\\Subscribed', '\\HasNoChildren' ]
)} @user2_mailboxes),
});
}
Expand All @@ -206,4 +221,31 @@ sub test_subscribe_prefix
$self->shared_subscribe_common('chris', 'christopher');
}

sub test_subscribe_vd
:VirtDomains :CrossDomains
{
my ($self) = @_;

$self->shared_subscribe_common('[email protected]',
'[email protected]');
}

sub test_subscribe_vd_prefix
:VirtDomains :CrossDomains
{
my ($self) = @_;

$self->shared_subscribe_common('[email protected]',
'[email protected]');
}

sub test_subscribe_vd_prefix2
:VirtDomains :CrossDomains
{
my ($self) = @_;

$self->shared_subscribe_common('[email protected]',
'[email protected]');
}

1;

0 comments on commit 9ae5781

Please sign in to comment.