-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
4 changed files
with
129 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
99 changes: 99 additions & 0 deletions
99
src/test/groovy/com/dtolabs/rundeck/plugin/resources/ec2/EC2ResourceModelSourceSpec.groovy
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
package com.dtolabs.rundeck.plugin.resources.ec2 | ||
|
||
import com.dtolabs.rundeck.core.common.Framework | ||
import com.dtolabs.rundeck.core.common.IRundeckProject | ||
import com.dtolabs.rundeck.core.common.ProjectManager | ||
import com.dtolabs.rundeck.core.storage.keys.KeyStorageTree | ||
import org.rundeck.app.spi.Services | ||
import spock.lang.Specification | ||
|
||
class EC2ResourceModelSourceSpec extends Specification { | ||
def "user configured access credentials prefer key storage"() { | ||
given: "a user's plugin config" | ||
//Define good and bad keys and paths | ||
def validAccessKey = "validAccessKey" | ||
def validSecretKey = "validSecretKey" | ||
def validKeyPath = "keys/validKeyPath" | ||
def badPath = "keys/badPath" | ||
def badPass = "myNetflixPassword" | ||
|
||
// Mock services and Key Storage return of passwords | ||
def serviceWithGoodPass = mockServicesWithPassword(validKeyPath, validSecretKey) | ||
def serviceWithBadPass = mockServicesWithPassword(badPath, badPass) | ||
|
||
// Create a default config object (these are the settings the user would setup via the Plugin UI) | ||
def defaultConfig = createDefaultConfig() | ||
defaultConfig.setProperty(EC2ResourceModelSourceFactory.ACCESS_KEY, validAccessKey) | ||
|
||
// Create a working config from the defaults | ||
def workingConfig = new Properties() | ||
workingConfig.putAll(defaultConfig) | ||
// Send a bad key to ensure key path takes precedence and succeeds | ||
workingConfig.setProperty(EC2ResourceModelSourceFactory.SECRET_KEY, badPass) | ||
workingConfig.setProperty(EC2ResourceModelSourceFactory.SECRET_KEY_STORAGE_PATH, validKeyPath) | ||
|
||
// Create a failing config from the defaults | ||
def failingConfig = new Properties() | ||
failingConfig.putAll(defaultConfig) | ||
// Send a valid key to ensure storage path takes precedence and fails | ||
failingConfig.setProperty(EC2ResourceModelSourceFactory.SECRET_KEY, validSecretKey) | ||
failingConfig.setProperty(EC2ResourceModelSourceFactory.SECRET_KEY_STORAGE_PATH, badPath) | ||
|
||
// Create objects using actual ResourceModelSource and Factory | ||
def workingRms = ec2ResourceModelSource(serviceWithGoodPass, workingConfig) | ||
def failingRms = ec2ResourceModelSource(serviceWithBadPass, failingConfig) | ||
|
||
when: "we check the access keys of the resource model source objects" | ||
// Instead of using getNodes, which would all be highly mocked, just check that we got as far as setting | ||
// proper credentials right before the point we would call to AWS | ||
def workingRmsPass = workingRms.credentials.getAWSSecretKey() | ||
def failingRmsPass = failingRms.credentials.getAWSSecretKey() | ||
|
||
then: "we see that the proper keys from the key storage or the inline key have been derived" | ||
workingRmsPass == validSecretKey | ||
failingRmsPass == badPass | ||
} | ||
// | ||
// Private Methods | ||
// | ||
private def createDefaultConfig() { | ||
def configuration = new Properties() | ||
def assumeRoleArn = "arn:aws:iam::123456789012:role/fake-test-arn" | ||
def endpoint = "ALL_REGIONS" | ||
def pageResults = "100" | ||
def proxyPortStr = "80" | ||
def refreshStr = "30" | ||
def useDefaultMapping = "true" | ||
def runningOnly = "true" | ||
|
||
configuration.setProperty(EC2ResourceModelSourceFactory.ROLE_ARN, assumeRoleArn) | ||
configuration.setProperty(EC2ResourceModelSourceFactory.ENDPOINT, endpoint); | ||
configuration.setProperty(EC2ResourceModelSourceFactory.MAX_RESULTS, pageResults); | ||
configuration.setProperty(EC2ResourceModelSourceFactory.HTTP_PROXY_PORT, proxyPortStr); | ||
configuration.setProperty(EC2ResourceModelSourceFactory.REFRESH_INTERVAL, refreshStr); | ||
configuration.setProperty(EC2ResourceModelSourceFactory.USE_DEFAULT_MAPPING, useDefaultMapping) | ||
configuration.setProperty(EC2ResourceModelSourceFactory.RUNNING_ONLY, runningOnly) | ||
|
||
return configuration | ||
} | ||
|
||
private def ec2ResourceModelSource(Services services, Properties configuration) { | ||
def framework = Mock(Framework) | ||
def factory = new EC2ResourceModelSourceFactory(framework) | ||
|
||
return factory.createResourceModelSource(services, configuration) | ||
} | ||
|
||
private def mockServicesWithPassword(String path, String password) { | ||
def storageTree = Mock(KeyStorageTree) { | ||
readPassword(path) >> { | ||
return password.bytes | ||
} | ||
} | ||
|
||
def services = Mock(Services) { | ||
getService(KeyStorageTree.class) >> storageTree | ||
} | ||
|
||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters