{-# LANGUAGE DeriveDataTypeable #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE TypeFamilies #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Network.AWS.DeviceFarm.ListTests -- Copyright : (c) 2013-2015 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Gets information about tests. -- -- /See:/ for ListTests. module Network.AWS.DeviceFarm.ListTests ( -- * Creating a Request listTests , ListTests -- * Request Lenses , ltNextToken , ltArn -- * Destructuring the Response , listTestsResponse , ListTestsResponse -- * Response Lenses , ltrsTests , ltrsNextToken , ltrsResponseStatus ) where import Network.AWS.DeviceFarm.Types import Network.AWS.DeviceFarm.Types.Product import Network.AWS.Lens import Network.AWS.Prelude import Network.AWS.Request import Network.AWS.Response -- | Represents a request to the list tests operation. -- -- /See:/ 'listTests' smart constructor. data ListTests = ListTests' { _ltNextToken :: !(Maybe Text) , _ltArn :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'ListTests' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ltNextToken' -- -- * 'ltArn' listTests :: Text -- ^ 'ltArn' -> ListTests listTests pArn_ = ListTests' { _ltNextToken = Nothing , _ltArn = pArn_ } -- | An identifier that was returned from the previous call to this -- operation, which can be used to return the next set of items in the -- list. ltNextToken :: Lens' ListTests (Maybe Text) ltNextToken = lens _ltNextToken (\ s a -> s{_ltNextToken = a}); -- | The tests\' ARNs. ltArn :: Lens' ListTests Text ltArn = lens _ltArn (\ s a -> s{_ltArn = a}); instance AWSRequest ListTests where type Rs ListTests = ListTestsResponse request = postJSON deviceFarm response = receiveJSON (\ s h x -> ListTestsResponse' <$> (x .?> "tests" .!@ mempty) <*> (x .?> "nextToken") <*> (pure (fromEnum s))) instance ToHeaders ListTests where toHeaders = const (mconcat ["X-Amz-Target" =# ("DeviceFarm_20150623.ListTests" :: ByteString), "Content-Type" =# ("application/x-amz-json-1.1" :: ByteString)]) instance ToJSON ListTests where toJSON ListTests'{..} = object (catMaybes [("nextToken" .=) <$> _ltNextToken, Just ("arn" .= _ltArn)]) instance ToPath ListTests where toPath = const "/" instance ToQuery ListTests where toQuery = const mempty -- | Represents the result of a list tests request. -- -- /See:/ 'listTestsResponse' smart constructor. data ListTestsResponse = ListTestsResponse' { _ltrsTests :: !(Maybe [Test]) , _ltrsNextToken :: !(Maybe Text) , _ltrsResponseStatus :: !Int } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'ListTestsResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ltrsTests' -- -- * 'ltrsNextToken' -- -- * 'ltrsResponseStatus' listTestsResponse :: Int -- ^ 'ltrsResponseStatus' -> ListTestsResponse listTestsResponse pResponseStatus_ = ListTestsResponse' { _ltrsTests = Nothing , _ltrsNextToken = Nothing , _ltrsResponseStatus = pResponseStatus_ } -- | Information about the tests. ltrsTests :: Lens' ListTestsResponse [Test] ltrsTests = lens _ltrsTests (\ s a -> s{_ltrsTests = a}) . _Default . _Coerce; -- | If the number of items that are returned is significantly large, this is -- an identifier that is also returned, which can be used in a subsequent -- call to this operation to return the next set of items in the list. ltrsNextToken :: Lens' ListTestsResponse (Maybe Text) ltrsNextToken = lens _ltrsNextToken (\ s a -> s{_ltrsNextToken = a}); -- | The response status code. ltrsResponseStatus :: Lens' ListTestsResponse Int ltrsResponseStatus = lens _ltrsResponseStatus (\ s a -> s{_ltrsResponseStatus = a});