import json import moto.server as server def test_sign_up_method_without_authentication(): backend = server.create_backend_app("cognito-idp") test_client = backend.test_client() # Create User Pool res = test_client.post( "/", data='{"PoolName": "test-pool"}', headers={ "X-Amz-Target": "AWSCognitoIdentityProviderService.CreateUserPool", "Authorization": "AWS4-HMAC-SHA256 Credential=abcd/20010101/us-east-2/s3/aws4_request, SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=...", }, ) user_pool_id = json.loads(res.data)["UserPool"]["Id"] # Create User Pool Client data = { "UserPoolId": user_pool_id, "ClientName": "some-client", "GenerateSecret": False, "ExplicitAuthFlows": ["ALLOW_USER_PASSWORD_AUTH"], } res = test_client.post( "/", data=json.dumps(data), headers={ "X-Amz-Target": "AWSCognitoIdentityProviderService.CreateUserPoolClient", "Authorization": "AWS4-HMAC-SHA256 Credential=abcd/20010101/us-east-2/s3/aws4_request, SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=...", }, ) client_id = json.loads(res.data)["UserPoolClient"]["ClientId"] # List User Pool Clients, to verify it exists data = {"UserPoolId": user_pool_id} res = test_client.post( "/", data=json.dumps(data), headers={ "X-Amz-Target": "AWSCognitoIdentityProviderService.ListUserPoolClients", "Authorization": "AWS4-HMAC-SHA256 Credential=abcd/20010101/us-east-2/s3/aws4_request, SignedHeaders=host;x-amz-content-sha256;x-amz-date, Signature=...", }, ) json.loads(res.data)["UserPoolClients"].should.have.length_of(1) # Sign Up User data = {"ClientId": client_id, "Username": "test@gmail.com", "Password": "12345678"} res = test_client.post( "/", data=json.dumps(data), headers={"X-Amz-Target": "AWSCognitoIdentityProviderService.SignUp"}, ) res.status_code.should.equal(200) json.loads(res.data).should.have.key("UserConfirmed").equals(False) # Confirm Sign Up User data = { "ClientId": client_id, "Username": "test@gmail.com", "ConfirmationCode": "sth", } res = test_client.post( "/", data=json.dumps(data), headers={"X-Amz-Target": "AWSCognitoIdentityProviderService.ConfirmSignUp"}, ) # Initiate Auth data = { "ClientId": client_id, "AuthFlow": "USER_PASSWORD_AUTH", "AuthParameters": {"USERNAME": "test@gmail.com", "PASSWORD": "12345678"}, } res = test_client.post( "/", data=json.dumps(data), headers={"X-Amz-Target": "AWSCognitoIdentityProviderService.InitiateAuth"}, ) res.status_code.should.equal(200) access_token = json.loads(res.data)["AuthenticationResult"]["AccessToken"] # Get User data = {"AccessToken": access_token} res = test_client.post( "/", data=json.dumps(data), headers={"X-Amz-Target": "AWSCognitoIdentityProviderService.GetUser"}, ) res.status_code.should.equal(200) data = json.loads(res.data) data.should.have.key("UserPoolId").equals(user_pool_id) data.should.have.key("Username").equals("test@gmail.com") data.should.have.key("UserStatus").equals("CONFIRMED")