2022-09-29 12:33:33 +02:00
/ *
GoToSocial
2023-03-12 16:00:57 +01:00
Copyright ( C ) GoToSocial Authors admin @ gotosocial . org
2022-09-29 12:33:33 +02:00
This program is free software : you can redistribute it and / or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation , either version 3 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU Affero General Public License for more details .
You should have received a copy of the GNU Affero General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
* /
2023-01-02 13:10:50 +01:00
package statuses_test
2022-09-29 12:33:33 +02:00
import (
"encoding/json"
"errors"
"fmt"
2024-04-26 13:50:46 +01:00
"io"
2022-09-29 12:33:33 +02:00
"net/http"
"net/http/httptest"
"strings"
"testing"
"github.com/gin-gonic/gin"
"github.com/stretchr/testify/suite"
2023-01-02 13:10:50 +01:00
"github.com/superseriousbusiness/gotosocial/internal/api/client/statuses"
apimodel "github.com/superseriousbusiness/gotosocial/internal/api/model"
2022-09-29 12:33:33 +02:00
"github.com/superseriousbusiness/gotosocial/internal/db"
"github.com/superseriousbusiness/gotosocial/internal/oauth"
"github.com/superseriousbusiness/gotosocial/testrig"
)
type StatusDeleteTestSuite struct {
StatusStandardTestSuite
}
func ( suite * StatusDeleteTestSuite ) TestPostDelete ( ) {
t := suite . testTokens [ "local_account_1" ]
oauthToken := oauth . DBTokenToToken ( t )
targetStatus := suite . testStatuses [ "local_account_1_status_1" ]
// setup
recorder := httptest . NewRecorder ( )
ctx , _ := testrig . CreateGinTestContext ( recorder , nil )
ctx . Set ( oauth . SessionAuthorizedApplication , suite . testApplications [ "application_1" ] )
ctx . Set ( oauth . SessionAuthorizedToken , oauthToken )
ctx . Set ( oauth . SessionAuthorizedUser , suite . testUsers [ "local_account_1" ] )
ctx . Set ( oauth . SessionAuthorizedAccount , suite . testAccounts [ "local_account_1" ] )
2023-01-02 13:10:50 +01:00
ctx . Request = httptest . NewRequest ( http . MethodDelete , fmt . Sprintf ( "http://localhost:8080%s" , strings . Replace ( statuses . BasePathWithID , ":id" , targetStatus . ID , 1 ) ) , nil ) // the endpoint we're hitting
2022-09-29 12:33:33 +02:00
ctx . Request . Header . Set ( "accept" , "application/json" )
// normally the router would populate these params from the path values,
// but because we're calling the function directly, we need to set them manually.
ctx . Params = gin . Params {
gin . Param {
2023-01-02 13:10:50 +01:00
Key : statuses . IDKey ,
2022-09-29 12:33:33 +02:00
Value : targetStatus . ID ,
} ,
}
suite . statusModule . StatusDELETEHandler ( ctx )
// check response
suite . EqualValues ( http . StatusOK , recorder . Code )
result := recorder . Result ( )
defer result . Body . Close ( )
2024-04-26 13:50:46 +01:00
b , err := io . ReadAll ( result . Body )
2022-09-29 12:33:33 +02:00
suite . NoError ( err )
2023-01-02 13:10:50 +01:00
statusReply := & apimodel . Status { }
2022-09-29 12:33:33 +02:00
err = json . Unmarshal ( b , statusReply )
suite . NoError ( err )
suite . NotNil ( statusReply )
if ! testrig . WaitFor ( func ( ) bool {
_ , err := suite . db . GetStatusByID ( ctx , targetStatus . ID )
return errors . Is ( err , db . ErrNoEntries )
} ) {
suite . FailNow ( "time out waiting for status to be deleted" )
}
}
func TestStatusDeleteTestSuite ( t * testing . T ) {
suite . Run ( t , new ( StatusDeleteTestSuite ) )
}