/** @test */
 public function building_returns_an_instance_of_attribute_statement_mapping_rules()
 {
     $builder = new \Stormpath\Saml\AttributeStatementMappingRuleBuilder();
     $builder->setName('test');
     $builder->setNameFormat('urn:oasis:names:tc:SAML:1.1:nameid-format:email');
     $builder->setAccountAttributes(['email', 'username']);
     $this->assertInstanceOf('Stormpath\\Saml\\AttributeStatementMappingRule', $builder->build());
 }
 /** @test */
 public function a_built_rule_has_getters_available_to_it()
 {
     $builder = new \Stormpath\Saml\AttributeStatementMappingRuleBuilder();
     $builder->setName('test');
     $builder->setNameFormat('urn:oasis:names:tc:SAML:1.1:nameid-format:email');
     $builder->setAccountAttributes(['email', 'username']);
     $rule = $builder->build();
     $this->assertEquals('test', $rule->getName());
     $this->assertEquals('urn:oasis:names:tc:SAML:1.1:nameid-format:email', $rule->getNameFormat());
     $this->assertEquals(['email', 'username'], $rule->getAccountAttributes());
 }
 /** @test */
 public function a_provider_can_save_an_attribute_statement_mapping_rule()
 {
     $samlProvider = \Stormpath\Resource\SamlProvider::instantiate(['ssoLoginUrl' => 'http://google.com/login', 'ssoLogoutUrl' => 'http://google.com/logout', 'encodedX509SigningCert' => self::getDummyCertForSaml(), 'requestSignatureAlgorithm' => 'RSA-SHA1']);
     $directory = \Stormpath\Resource\Directory::create(['name' => makeUniqueName('DirectoryTest samlProvider'), 'provider' => $samlProvider]);
     $providerHref = $directory->provider->href;
     $provider = SamlProvider::get($providerHref);
     $ruleBuilder = new \Stormpath\Saml\AttributeStatementMappingRuleBuilder();
     $rule = $ruleBuilder->setName('test1')->setAccountAttributes(['customData.test1'])->build();
     $rule2 = $ruleBuilder->setName('test2')->setAccountAttributes(['customData.test2'])->build();
     $rulesBuilder = new \Stormpath\Saml\AttributeStatementMappingRulesBuilder();
     $rulesBuilder->setAttributeStatementMappingRules([$rule, $rule2]);
     $rules = $rulesBuilder->build();
     $provider->setAttributeStatementMappingRules($rules);
     $provider->save();
     $provider = SamlProvider::get($providerHref);
     $mappingRules = $provider->getAttributeStatementMappingRules();
     $this->assertCount(2, $mappingRules->items);
     foreach ($mappingRules->items as $item) {
         $this->assertInstanceOf('Stormpath\\Saml\\AttributeStatementMappingRule', $item);
     }
     $this->assertEquals('test2', $mappingRules->items[1]->name);
     $directory->delete();
 }