Consulta ao Firestore - verificando se o nome de usuário já existe

Preciso de ajuda com as consultas do Firestore. eu tenho umall_users coleta de dados, documentos de identificação do usuário com cada informação do usuário.imagem de banco de dados do firestore Eu quero verificar se o nome de usuário já existe. Eu entendo como obter documentos () e comparar como demonstrado em sua página da Web, mas e a consulta de dados ?, este é o meu código

atualizando os widgets - (se o campo de texto mUser e o nome de usuário atual não forem iguais)

 private void saveProfileSettings(){
    final String username = mUsername.getText().toString();
    //Case 1: user did not change their username
    if (!mUsers.getUsername().equals(username)){

        checkingIfusernameExist(username);

    }else {

    }
}

métodoeckingIfusernameExist

    private void checkingIfusernameExist(final String username){
    Log.d(TAG, "checkingIfusernameExist: Checking if " + username + " Exists");

    Query mQuery = mFirebaseFirestore.collection("all_users")
            .orderBy(getString(R.string.fields_username))
            .whereEqualTo("username", username);

    mQuery.addSnapshotListener(new EventListener<QuerySnapshot>() {
        @Override
        public void onEvent(QuerySnapshot documentSnapshots, FirebaseFirestoreException e) {

            if (documentSnapshots != null){
                Log.d(TAG, "onEvent: username does not exists");
                Toast.makeText(getActivity(), "Username is available", Toast.LENGTH_SHORT).show();
            }
            for (DocumentSnapshot ds: documentSnapshots){
                if (ds.exists()){
                    Log.d(TAG, "checkingIfusernameExist: FOUND A MATCH: " + ds.toObject(Users.class).getUsername());
                    Toast.makeText(getActivity(), "That username already exists.", Toast.LENGTH_SHORT).show();
                }
            }
        }
    });
 }

Não recebo erros nem resultados. Eu procurei em todos os lugares e não vi problemas como os meus. Além disso, não há muitas consultas em torno das quais eu possa trabalhar. qualquer correção seria apreciada, obrigado antecipadamente.

ATUALIZAÇÃO: após dias de pesquisa, na verdade, surgiu uma solução com a ajuda das respostas que obtive abaixo. portanto, como o firestore não possui uma lógica operacional e você deseja atualizar se o nome de usuário não existir com o .whereEqualTo, use a tarefa para localizar se há carga útil.

código que funcionou para mim

métodoeckingIfUsernameExists

private void checkingIfusernameExist(final String usernameToCompare){

    //----------------------------------------------------------------
    final Query mQuery = mFirebaseFirestore.collection("all_users").whereEqualTo("username", usernameToCompare);
    mQuery.get().addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
        @Override
        public void onComplete(@NonNull Task<QuerySnapshot> task) {
            Log.d(TAG, "checkingIfusernameExist: checking if username exists");

            if (task.isSuccessful()){
                for (DocumentSnapshot ds: task.getResult()){
                    String userNames = ds.getString("username");
                        if (userNames.equals(usernameToCompare)) {
                            Log.d(TAG, "checkingIfusernameExist: FOUND A MATCH -username already exists");
                            Toast.makeText(getActivity(), "username already exists", Toast.LENGTH_SHORT).show();
                        }
                }
            }
            //checking if task contains any payload. if no, then update
            if (task.getResult().size() == 0){
                try{

                Log.d(TAG, "onComplete: MATCH NOT FOUND - username is available");
                Toast.makeText(getActivity(), "username changed", Toast.LENGTH_SHORT).show();
                //Updating new username............


                }catch (NullPointerException e){
                    Log.e(TAG, "NullPointerException: " + e.getMessage() );
                }
            }
        }
    });

questionAnswers(3)

yourAnswerToTheQuestion