A clean, Markdown-based publishing platform made for writers. Write together, and build a community. https://writefreely.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

51 lines
1.6 KiB

  1. package writefreely
  2. import (
  3. "context"
  4. "database/sql"
  5. "github.com/stretchr/testify/assert"
  6. "testing"
  7. )
  8. func TestOAuthDatastore(t *testing.T) {
  9. if !runMySQLTests() {
  10. t.Skip("skipping mysql tests")
  11. }
  12. withTestDB(t, func(db *sql.DB) {
  13. ctx := context.Background()
  14. ds := &datastore{
  15. DB: db,
  16. driverName: "",
  17. }
  18. state, err := ds.GenerateOAuthState(ctx, "test", "development")
  19. assert.NoError(t, err)
  20. assert.Len(t, state, 24)
  21. countRows(t, ctx, db, 1, "SELECT COUNT(*) FROM `oauth_client_states` WHERE `state` = ? AND `used` = false", state)
  22. _, _, err = ds.ValidateOAuthState(ctx, state)
  23. assert.NoError(t, err)
  24. countRows(t, ctx, db, 1, "SELECT COUNT(*) FROM `oauth_client_states` WHERE `state` = ? AND `used` = true", state)
  25. var localUserID int64 = 99
  26. var remoteUserID = "100"
  27. err = ds.RecordRemoteUserID(ctx, localUserID, remoteUserID, "test", "test", "access_token_a")
  28. assert.NoError(t, err)
  29. countRows(t, ctx, db, 1, "SELECT COUNT(*) FROM `oauth_users` WHERE `user_id` = ? AND `remote_user_id` = ? AND access_token = 'access_token_a'", localUserID, remoteUserID)
  30. err = ds.RecordRemoteUserID(ctx, localUserID, remoteUserID, "test", "test", "access_token_b")
  31. assert.NoError(t, err)
  32. countRows(t, ctx, db, 1, "SELECT COUNT(*) FROM `oauth_users` WHERE `user_id` = ? AND `remote_user_id` = ? AND access_token = 'access_token_b'", localUserID, remoteUserID)
  33. countRows(t, ctx, db, 1, "SELECT COUNT(*) FROM `oauth_users`")
  34. foundUserID, err := ds.GetIDForRemoteUser(ctx, remoteUserID, "test", "test")
  35. assert.NoError(t, err)
  36. assert.Equal(t, localUserID, foundUserID)
  37. })
  38. }