我只是尝试一些基本的Uber Cadence示例。我面临的问题如下:我有一个活动,该活动接收一个结构作为参数并更改值并返回修改后的结构。执行工作流时我无法获取修改后的值。它显示默认值。我尝试如下代码片段:
type Product struct {
vendor string // "Arrows"
productCategory string // "Clothing"
productName string // "Shirt"
description string // "Shirt for Gents"
size int // 42
cost float32// 2.00
color string // "Red"
auctionOption string // "Buy it Now"
}
// populateProduct
func newProduct() *Product {
p := Product{vendor: "Arrows"}
p.productCategory = "Clothing"
p.productName = "Shirt"
p.description = "Shirt for Gents"
p.size = 42
p.cost = 2.00
p.color = "Red"
p.auctionOption = "Buy it Now"
return &p
}
// Activity
func NewProductActivity(ctx context.Context) (*Product, error) {
logger := activity.GetLogger(ctx)
logger.Info("NewProductActivity started.................")
np := newProduct()
return np, nil
}
// Workflow
func MarketPlaceWorkflow(ctx workflow.Context, name string) (string, error) {
ctx = workflow.WithActivityOptions(ctx, activityOptions)
logger := workflow.GetLogger(ctx)
logger.Info("MarketPlace workflow started!................")
// Invoking NewProductActivity
var npActivityResult Product
err := workflow.ExecuteActivity(ctx, NewProductActivity).Get(ctx, &npActivityResult)
if err != nil {
logger.Error("MarketPlace workflow NewProductActivity failed!.............", zap.Error(err))
return "", err
}
logger.Info("Vendor: ", zap.String("Vendor", npActivityResult.vendor)) // It is showing default values
return "", nil
}
Cadence和Temporal在默认情况下使用encoding/json包对活动输入和输出进行序列化和反序列化。该程序包不序列化私有字段。因此,在您的情况下,由于所有字段都是私有的,因此当它们从活动传递到工作流时,它们将被忽略。将您的代码更改为:
类型产品结构{ 供应商字符串//“箭头” productCategory字符串//“服装” productName字符串//“衬衫” description字符串//“男士衬衫” 尺寸整数// 42 费用float32 // 2.00 颜色字符串//“红色” auctionOption字符串//“立即购买” }
// populateProduct
func newProduct() *Product {
p := Product{Vendor: "Arrows"}
p.ProductCategory = "Clothing"
p.ProductName = "Shirt"
p.Description = "Shirt for Gents"
p.Size = 42
p.Cost = 2.00
p.Color = "Red"
p.AuctionOption = "Buy it Now"
return &p
}
// Activity
func NewProductActivity(ctx context.Context) (*Product, error) {
logger := activity.GetLogger(ctx)
logger.Info("NewProductActivity started.................")
np := newProduct()
return np, nil
}
// Workflow
func MarketPlaceWorkflow(ctx workflow.Context, name string) (string, error) {
ctx = workflow.WithActivityOptions(ctx, activityOptions)
logger := workflow.GetLogger(ctx)
logger.Info("MarketPlace workflow started!................")
// Invoking NewProductActivity
var npActivityResult Product
err := workflow.ExecuteActivity(ctx, NewProductActivity).Get(ctx, &npActivityResult)
if err != nil {
logger.Error("MarketPlace workflow NewProductActivity failed!.............", zap.Error(err))
return "", err
}
logger.Info("Vendor: ", zap.String("Vendor", npActivityResult.Vendor))
return "", nil
}