Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

36-feat-card-transactions #48

Draft
wants to merge 10 commits into
base: main
Choose a base branch
from

Conversation

parthux1
Copy link

@parthux1 parthux1 commented Nov 21, 2024

closes #36

As of now the implementation writes Card payment information to the already generated CSV.

Polluted fields:

field value
ID generated as in other rows
Status generated as in other rows
Timestamp date of transaction
Type Cash
Name Beneficiary (name)
Debit amount payed

whats missing for this PR to be closed (IMO)

  • prevent log warnings for fields unique for card payment transactions
  • tests
  • map available IBAN letters to CSV (first 4 numbers are available)
  • maybe append Readme
  • validate detector (no data available for failed transactions from my side, marked as TODO in-code)

I hope I utilized the corresponding patterns correctly and sticked to your style. As it's my first time writing Go I'd be grateful if you comment if you see a problem with the used style&approaches.

@dhojayev
Copy link
Owner

Hey @parthux1 ,
It is so great to see the first external PR.
I would highly suggest to start with test data. If you need some help - I can help you.
With that you will adhere to TDD principles and would be able to simulate processing card transactions without needing real data from TR.
Some examples to start with are:

Test cases contain all responses and their "normalized" state. With that it will help both you and me to make sure that changes are working.

Again, if you need help, we can chat and I can help you setting it up.
Let me know.

@parthux1
Copy link
Author

parthux1 commented Dec 5, 2024

FYI; I'm currently moving. I'll implement your suggestions as soon as I'm done and have my new wifi.

…rteile"

Headers correspond to the UI elements with the same naming in the TR-App when viewing a payment transcation.
"Vorteile":

contains potential saveback payments.

Example
```
{
      "data": [
        {
          "detail": {
            "action": {
              "type": "benefitsSavebackOverview"
            },
            "amount": "XXX €",
            "icon": "logos/IE0031442068/v2",
            "status": "executed",
            "subtitle": "Saveback",
            "timestamp": "2024-04-07T18:03:34.802+0000",
            "title": "Core S\u0026P 500 USD (Dist)",
            "type": "embeddedTimelineItem"
          },
          "style": "plain",
          "title": "Core S\u0026P 500 USD (Dist)"
        }
      ],
      "title": "Vorteile",
      "type": "table"
    }
```

"Hilfe":

contains transction ids

Example
```
    {
      "data": [
        {
          "detail": {
            "action": {
              "payload": {
                "contextCategory": "card-dispute",
                "contextParams": {
                  "card-dispute-txId": "XXXXXXXXXXXXXXXXXXXXXXXXXX"
                },
                "transactionId": "XXXXXXXXXXXXXXXXXXXXXXXXX"
              },
              "type": "customerSupportChat"
            },
            "icon": "logos/timeline_communication/v2",
            "type": "listItemAvatarDefault"
          },
          "style": "highlighted",
          "title": "Problem melden"
        }
      ],
      "title": "Hilfe",
      "type": "table"
    }
```
@parthux1
Copy link
Author

parthux1 commented Jan 14, 2025

Hello dhojayev,

both linked test cases seem to be for testing the unimplemented feature I'm currently working on.
Thus I'll modify them.

In my last commit I appended data for all parameters of TransactionTestCase except of parameter TimelineTransactionsData in the first testcase.

Even when looking at a similar test I don't understand what should be stored in ``TimelineTransactionsData`.

I tried adding the content of json element "data" (line 66 in commited tests/fakes/card_successful_transaction_01.go) which causes the same issue. Thus it's not present in the commit.

Maybe you could point me in the right direction regarding this issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Implement writing TR card transactions into CSV file
2 participants