See
<https://ci-beam.apache.org/job/beam_PostCommit_XVR_GoUsingJava_Dataflow/1664/display/redirect>
Changes:
------------------------------------------
[...truncated 1.06 MB...]
"beam:coder:varint:v1",
"beam:coder:string_utf8:v1",
"beam:coder:iterable:v1",
"beam:coder:timer:v1",
"beam:coder:kv:v1",
"beam:coder:length_prefix:v1",
"beam:coder:global_window:v1",
"beam:coder:interval_window:v1",
"beam:coder:custom_window:v1",
"beam:coder:windowed_value:v1",
"beam:coder:double:v1",
"beam:coder:row:v1",
"beam:coder:param_windowed_value:v1",
"beam:coder:state_backed_iterable:v1",
"beam:coder:sharded_key:v1",
"beam:coder:nullable:v1",
"beam:protocol:multi_core_bundle_processing:v1",
"beam:protocol:progress_reporting:v1",
"beam:protocol:harness_monitoring_infos:v1",
"beam:protocol:control_request_elements_embedding:v1",
"beam:protocol:state_caching:v1",
"beam:version:sdk_base:apache/beam_java8_sdk:2.49.0.dev",
"beam:transform:sdf_truncate_sized_restrictions:v1",
"beam:transform:to_string:v1",
"beam:protocol:data_sampling:v1"
],
"containerImage":
"us.gcr.io/apache-beam-testing/java-postcommit-it/java:20230522022040",
"environmentId": "NaTQCiTbwtbeam:env:docker:v1"
}
],
"workerHarnessContainerImage":
"us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk:20230522-023131"
}
]
},
"name": "go-testxlang_partition-76",
"projectId": "apache-beam-testing",
"type": "JOB_TYPE_BATCH"
}
2023/05/22 03:13:54 Submitted job: 2023-05-21_20_13_53-18344757554409808505
2023/05/22 03:13:54 Console:
https://console.cloud.google.com/dataflow/jobs/us-central1/2023-05-21_20_13_53-18344757554409808505?project=apache-beam-testing
2023/05/22 03:13:54 Logs:
https://console.cloud.google.com/logs/viewer?project=apache-beam-testing&resource=dataflow_step%2Fjob_id%2F2023-05-21_20_13_53-18344757554409808505
2023/05/22 03:13:54 Job state: JOB_STATE_PENDING ...
2023/05/22 03:14:24 Job still running ...
2023/05/22 03:14:54 Job still running ...
2023/05/22 03:15:24 Job still running ...
2023/05/22 03:15:54 Job still running ...
2023/05/22 03:16:24 Job still running ...
2023/05/22 03:16:54 Job still running ...
2023/05/22 03:17:24 Job still running ...
2023/05/22 03:17:54 Job still running ...
2023/05/22 03:18:24 Job still running ...
2023/05/22 03:18:54 Job still running ...
2023/05/22 03:19:24 Job still running ...
2023/05/22 03:19:54 Job still running ...
2023/05/22 03:20:24 Job still running ...
2023/05/22 03:20:54 Job still running ...
2023/05/22 03:21:24 Job still running ...
2023/05/22 03:21:54 Job still running ...
2023/05/22 03:22:25 Job still running ...
ptest.go:108: Failed to execute job: Job
2023-05-21_20_13_53-18344757554409808505 failed
--- FAIL: TestXLang_Partition (549.85s)
FAIL
FAIL github.com/apache/beam/sdks/v2/go/test/integration/xlang
3054.159s
=== RUN TestBigQueryIO_BasicWriteRead
bigquery_test.go:213: Created BigQuery table
apache-beam-testing.beam_bigquery_io_test_temp.go_bqio_it_temp_1684722724272294353
--- FAIL: TestBigQueryIO_BasicWriteRead (4.56s)
panic: tried cross-language for
beam:transform:org.apache.beam:schemaio_bigquery_write:v1 against
localhost:35827 and failed
expanding external transform
expanding transform with ExpansionRequest:
components:{pcollections:{key:"n2" value:{unique_name:"n2"
coder_id:"c0@WaUawABmxc" is_bounded:BOUNDED
windowing_strategy_id:"w0@WaUawABmxc"}}
windowing_strategies:{key:"w0@WaUawABmxc"
value:{window_fn:{urn:"beam:window_fn:global_windows:v1"}
merge_status:NON_MERGING window_coder_id:"c1@WaUawABmxc" trigger:{default:{}}
accumulation_mode:DISCARDING output_time:END_OF_WINDOW
closing_behavior:EMIT_IF_NONEMPTY on_time_behavior:FIRE_IF_NONEMPTY
environment_id:"go"}} coders:{key:"c0@WaUawABmxc"
value:{spec:{urn:"beam:coder:row:v1"
payload:"\n\r\n\x07counter\x1a\x02\x10\x04\nZ\n\trand_data\x1aM2K\nI\n\n\n\x04flip\x1a\x02\x10\x08\n\t\n\x03num\x1a\x02\x10\x04\n\n\n\x04word\x1a\x02\x10\x07\x12$293279a3-cab2-4082-b6be-1729f646ba84\x12$40dfa07a-fadd-4e7a-ac47-7534633021ad"}}}
coders:{key:"c1@WaUawABmxc" value:{spec:{urn:"beam:coder:global_window:v1"}}}}
transform:{unique_name:"External"
spec:{urn:"beam:transform:org.apache.beam:schemaio_bigquery_write:v1"
payload:"\nX\n\x0e\n\x08location\x1a\x02\x10\x07\n\x0c\n\x06config\x1a\x02\x10\t\n\x12\n\ndataSchema\x1a\x04\x08\x01\x10\t\x12$3fc24beb-ef0b-4fd0-b491-64340b33ca1e\x12a\x03\x01\x04\x00\\\x04\x01\x06Rapache-beam-testing.beam_bigquery_io_test_temp.go_bqio_it_temp_1684722724272294353\x05Never"}
inputs:{key:"i0" value:"n2"} environment_id:"go"} namespace:"WaUawABmxc"
expansion response error
caused by:
java.lang.IllegalArgumentException: Triggering frequency or number of file
shards can be specified only when writing an unbounded PCollection via
FILE_LOADS or STORAGE_API_WRITES, but: the collection was BOUNDED and the
method was STORAGE_WRITE_API
at
org.apache.beam.vendor.guava.v26_0_jre.com.google.common.base.Preconditions.checkArgument(Preconditions.java:440)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO$Write.expand(BigQueryIO.java:3061)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO$Write.expand(BigQueryIO.java:2110)
at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:545)
at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:479)
at org.apache.beam.sdk.values.PCollection.apply(PCollection.java:352)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQuerySchemaIOProvider$BigQuerySchemaIO$2.expand(BigQuerySchemaIOProvider.java:228)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQuerySchemaIOProvider$BigQuerySchemaIO$2.expand(BigQuerySchemaIOProvider.java:193)
at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:545)
at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:496)
at
org.apache.beam.sdk.expansion.service.ExpansionService$TransformProvider.apply(ExpansionService.java:402)
at
org.apache.beam.sdk.expansion.service.ExpansionService.expand(ExpansionService.java:555)
at
org.apache.beam.sdk.expansion.service.ExpansionService.expand(ExpansionService.java:639)
at
org.apache.beam.model.expansion.v1.ExpansionServiceGrpc$MethodHandlers.invoke(ExpansionServiceGrpc.java:306)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.stub.ServerCalls$UnaryServerCallHandler$UnaryServerCallListener.onHalfClose(ServerCalls.java:182)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.ServerCallImpl$ServerStreamListenerImpl.halfClosed(ServerCallImpl.java:355)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.ServerImpl$JumpToApplicationThreadServerStreamListener$1HalfClosed.runInContext(ServerImpl.java:867)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.ContextRunnable.run(ContextRunnable.java:37)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.SerializingExecutor.run(SerializingExecutor.java:133)
at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:750)
[recovered]
panic: tried cross-language for
beam:transform:org.apache.beam:schemaio_bigquery_write:v1 against
localhost:35827 and failed
expanding external transform
expanding transform with ExpansionRequest:
components:{pcollections:{key:"n2" value:{unique_name:"n2"
coder_id:"c0@WaUawABmxc" is_bounded:BOUNDED
windowing_strategy_id:"w0@WaUawABmxc"}}
windowing_strategies:{key:"w0@WaUawABmxc"
value:{window_fn:{urn:"beam:window_fn:global_windows:v1"}
merge_status:NON_MERGING window_coder_id:"c1@WaUawABmxc" trigger:{default:{}}
accumulation_mode:DISCARDING output_time:END_OF_WINDOW
closing_behavior:EMIT_IF_NONEMPTY on_time_behavior:FIRE_IF_NONEMPTY
environment_id:"go"}} coders:{key:"c0@WaUawABmxc"
value:{spec:{urn:"beam:coder:row:v1"
payload:"\n\r\n\x07counter\x1a\x02\x10\x04\nZ\n\trand_data\x1aM2K\nI\n\n\n\x04flip\x1a\x02\x10\x08\n\t\n\x03num\x1a\x02\x10\x04\n\n\n\x04word\x1a\x02\x10\x07\x12$293279a3-cab2-4082-b6be-1729f646ba84\x12$40dfa07a-fadd-4e7a-ac47-7534633021ad"}}}
coders:{key:"c1@WaUawABmxc" value:{spec:{urn:"beam:coder:global_window:v1"}}}}
transform:{unique_name:"External"
spec:{urn:"beam:transform:org.apache.beam:schemaio_bigquery_write:v1"
payload:"\nX\n\x0e\n\x08location\x1a\x02\x10\x07\n\x0c\n\x06config\x1a\x02\x10\t\n\x12\n\ndataSchema\x1a\x04\x08\x01\x10\t\x12$3fc24beb-ef0b-4fd0-b491-64340b33ca1e\x12a\x03\x01\x04\x00\\\x04\x01\x06Rapache-beam-testing.beam_bigquery_io_test_temp.go_bqio_it_temp_1684722724272294353\x05Never"}
inputs:{key:"i0" value:"n2"} environment_id:"go"} namespace:"WaUawABmxc"
expansion response error
caused by:
java.lang.IllegalArgumentException: Triggering frequency or number of file
shards can be specified only when writing an unbounded PCollection via
FILE_LOADS or STORAGE_API_WRITES, but: the collection was BOUNDED and the
method was STORAGE_WRITE_API
at
org.apache.beam.vendor.guava.v26_0_jre.com.google.common.base.Preconditions.checkArgument(Preconditions.java:440)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO$Write.expand(BigQueryIO.java:3061)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQueryIO$Write.expand(BigQueryIO.java:2110)
at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:545)
at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:479)
at org.apache.beam.sdk.values.PCollection.apply(PCollection.java:352)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQuerySchemaIOProvider$BigQuerySchemaIO$2.expand(BigQuerySchemaIOProvider.java:228)
at
org.apache.beam.sdk.io.gcp.bigquery.BigQuerySchemaIOProvider$BigQuerySchemaIO$2.expand(BigQuerySchemaIOProvider.java:193)
at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:545)
at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:496)
at
org.apache.beam.sdk.expansion.service.ExpansionService$TransformProvider.apply(ExpansionService.java:402)
at
org.apache.beam.sdk.expansion.service.ExpansionService.expand(ExpansionService.java:555)
at
org.apache.beam.sdk.expansion.service.ExpansionService.expand(ExpansionService.java:639)
at
org.apache.beam.model.expansion.v1.ExpansionServiceGrpc$MethodHandlers.invoke(ExpansionServiceGrpc.java:306)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.stub.ServerCalls$UnaryServerCallHandler$UnaryServerCallListener.onHalfClose(ServerCalls.java:182)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.ServerCallImpl$ServerStreamListenerImpl.halfClosed(ServerCallImpl.java:355)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.ServerImpl$JumpToApplicationThreadServerStreamListener$1HalfClosed.runInContext(ServerImpl.java:867)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.ContextRunnable.run(ContextRunnable.java:37)
at
org.apache.beam.vendor.grpc.v1p54p0.io.grpc.internal.SerializingExecutor.run(SerializingExecutor.java:133)
at
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:750)
goroutine 25 [running]:
testing.tRunner.func1.2({0xfe27c0, 0xc000322700})
/home/jenkins/sdk/go1.20.4/src/testing/testing.go:1526 +0x24e
testing.tRunner.func1()
/home/jenkins/sdk/go1.20.4/src/testing/testing.go:1529 +0x39f
panic({0xfe27c0, 0xc000322700})
/home/jenkins/sdk/go1.20.4/src/runtime/panic.go:884 +0x213
github.com/apache/beam/sdks/v2/go/pkg/beam.CrossLanguage({0xc0006aa0e0?,
0xc0006ae050?}, {0x11cb21b, 0x39}, {0xc000158180?, 0x10ca800?, 0x41bcd1?},
{0xc000045f10, 0xf}, 0xc000299d20, ...)
<https://ci-beam.apache.org/job/beam_PostCommit_XVR_GoUsingJava_Dataflow/ws/src/sdks/go/pkg/beam/xlang.go>:165
+0x136
github.com/apache/beam/sdks/v2/go/pkg/beam/io/xlang/bigqueryio.Write({0xc0006aa060?,
0xc0006ae050?}, {0xc000050a20, 0x52}, {0x1?}, {0xc000299ea8, 0x2, 0xee22c0?})
<https://ci-beam.apache.org/job/beam_PostCommit_XVR_GoUsingJava_Dataflow/ws/src/sdks/go/pkg/beam/io/xlang/bigqueryio/bigquery.go>:252
+0x3d7
github.com/apache/beam/sdks/v2/go/test/integration/io/xlang/bigquery.WritePipeline({0xc000045f10,
0xf}, {0xc000050a20, 0x52}, {0xf26ee0, 0xc00068c038})
<https://ci-beam.apache.org/job/beam_PostCommit_XVR_GoUsingJava_Dataflow/ws/src/sdks/go/test/integration/io/xlang/bigquery/bigquery_test.go>:126
+0x205
github.com/apache/beam/sdks/v2/go/test/integration/io/xlang/bigquery.TestBigQueryIO_BasicWriteRead(0xc0000d7380)
<https://ci-beam.apache.org/job/beam_PostCommit_XVR_GoUsingJava_Dataflow/ws/src/sdks/go/test/integration/io/xlang/bigquery/bigquery_test.go>:216
+0x1ec
testing.tRunner(0xc0000d7380, 0x11fe750)
/home/jenkins/sdk/go1.20.4/src/testing/testing.go:1576 +0x10b
created by testing.(*T).Run
/home/jenkins/sdk/go1.20.4/src/testing/testing.go:1629 +0x3ea
FAIL github.com/apache/beam/sdks/v2/go/test/integration/io/xlang/bigquery
7.583s
=== RUN TestDebeziumIO_BasicRead
integration.go:310: Test TestDebeziumIO_BasicRead is currently filtered for
runner dataflow
--- SKIP: TestDebeziumIO_BasicRead (0.00s)
PASS
ok github.com/apache/beam/sdks/v2/go/test/integration/io/xlang/debezium
3.029s
=== RUN TestJDBCIO_BasicReadWrite
integration.go:310: Test TestJDBCIO_BasicReadWrite is currently filtered
for runner dataflow
--- SKIP: TestJDBCIO_BasicReadWrite (0.00s)
=== RUN TestJDBCIO_PostgresReadWrite
integration.go:310: Test TestJDBCIO_PostgresReadWrite is currently filtered
for runner dataflow
--- SKIP: TestJDBCIO_PostgresReadWrite (0.00s)
PASS
ok github.com/apache/beam/sdks/v2/go/test/integration/io/xlang/jdbc
3.025s
=== RUN TestKafkaIO_BasicReadWrite
integration.go:310: Test TestKafkaIO_BasicReadWrite is currently filtered
for runner dataflow
--- SKIP: TestKafkaIO_BasicReadWrite (0.00s)
PASS
ok github.com/apache/beam/sdks/v2/go/test/integration/io/xlang/kafka
6.023s
FAIL
$ TEST_EXIT_CODE=0
$ cd ../..
$ docker rmi us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk:20230522-023131
Untagged: us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk:20230522-023131
Untagged:
us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk@sha256:c871f6caaf76a544ffc214c9620bb2cc07de596073ede88b0c3923ca7a0202e3
Deleted: sha256:c0d3ffce6bb27f2edabd40d43e6a3a1ca040d549b82bb73d81281c44b8165f12
$ gcloud --quiet container images delete
us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk:20230522-023131
WARNING: Successfully resolved tag to sha256, but it is recommended to use
sha256 directly.
Digests:
-
us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk@sha256:c871f6caaf76a544ffc214c9620bb2cc07de596073ede88b0c3923ca7a0202e3
Associated tags:
- 20230522-023131
Tags:
- us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk:20230522-023131
Deleted [us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk:20230522-023131].
Deleted
[us.gcr.io/apache-beam-testing/jenkins/beam_go_sdk@sha256:c871f6caaf76a544ffc214c9620bb2cc07de596073ede88b0c3923ca7a0202e3].
$ rm -rf /tmp/tmp.4IFtNfbxcM
$ exit 1
$ exit 1
> Task
> :runners:google-cloud-dataflow-java:validatesCrossLanguageRunnerGoUsingJava
> FAILED
> Task :runners:google-cloud-dataflow-java:cleanupXVR UP-TO-DATE
> Task :runners:google-cloud-dataflow-java:cleanUpDockerPythonImages
Untagged: us.gcr.io/apache-beam-testing/java-postcommit-it/python:20230522022040
Untagged:
us.gcr.io/apache-beam-testing/java-postcommit-it/python@sha256:16c4407b5a4d00caf74ba4552ff39a624536ab069570cf471c94a27e81e67ad4
WARNING: Successfully resolved tag to sha256, but it is recommended to use
sha256 directly.
Tag: [us.gcr.io/apache-beam-testing/java-postcommit-it/python:20230522022040]
- referencing digest:
[us.gcr.io/apache-beam-testing/java-postcommit-it/python@sha256:16c4407b5a4d00caf74ba4552ff39a624536ab069570cf471c94a27e81e67ad4]
Deleted
[[us.gcr.io/apache-beam-testing/java-postcommit-it/python:20230522022040]
(referencing
[us.gcr.io/apache-beam-testing/java-postcommit-it/python@sha256:16c4407b5a4d00caf74ba4552ff39a624536ab069570cf471c94a27e81e67ad4])].
Removing untagged image
us.gcr.io/apache-beam-testing/java-postcommit-it/python@sha256:16c4407b5a4d00caf74ba4552ff39a624536ab069570cf471c94a27e81e67ad4
Digests:
-
us.gcr.io/apache-beam-testing/java-postcommit-it/python@sha256:16c4407b5a4d00caf74ba4552ff39a624536ab069570cf471c94a27e81e67ad4
Deleted
[us.gcr.io/apache-beam-testing/java-postcommit-it/python@sha256:16c4407b5a4d00caf74ba4552ff39a624536ab069570cf471c94a27e81e67ad4].
> Task :runners:google-cloud-dataflow-java:cleanUpDockerJavaImages
Untagged: us.gcr.io/apache-beam-testing/java-postcommit-it/java:20230522022040
Untagged:
us.gcr.io/apache-beam-testing/java-postcommit-it/java@sha256:8cc542ccec461eac1f10220dadb490c07771d67091a99cb4b99d055531143a67
WARNING: Successfully resolved tag to sha256, but it is recommended to use
sha256 directly.
Tag: [us.gcr.io/apache-beam-testing/java-postcommit-it/java:20230522022040]
- referencing digest:
[us.gcr.io/apache-beam-testing/java-postcommit-it/java@sha256:8cc542ccec461eac1f10220dadb490c07771d67091a99cb4b99d055531143a67]
Deleted [[us.gcr.io/apache-beam-testing/java-postcommit-it/java:20230522022040]
(referencing
[us.gcr.io/apache-beam-testing/java-postcommit-it/java@sha256:8cc542ccec461eac1f10220dadb490c07771d67091a99cb4b99d055531143a67])].
Removing untagged image
us.gcr.io/apache-beam-testing/java-postcommit-it/java@sha256:8cc542ccec461eac1f10220dadb490c07771d67091a99cb4b99d055531143a67
Digests:
-
us.gcr.io/apache-beam-testing/java-postcommit-it/java@sha256:8cc542ccec461eac1f10220dadb490c07771d67091a99cb4b99d055531143a67
Deleted
[us.gcr.io/apache-beam-testing/java-postcommit-it/java@sha256:8cc542ccec461eac1f10220dadb490c07771d67091a99cb4b99d055531143a67].
> Task :runners:google-cloud-dataflow-java:validatesCrossLanguageRunnerCleanup
Stopping expansion service pid: 498263.
Stopping expansion service pid: 498264.
FAILURE: Build failed with an exception.
* Where:
Build file
'<https://ci-beam.apache.org/job/beam_PostCommit_XVR_GoUsingJava_Dataflow/ws/src/sdks/go/test/build.gradle'>
line: 193
* What went wrong:
Execution failed for task
':runners:google-cloud-dataflow-java:validatesCrossLanguageRunnerGoUsingJava'.
> Process 'command 'sh'' finished with non-zero exit value 1
* Try:
> Run with --stacktrace option to get the stack trace.
> Run with --info or --debug option to get more log output.
* Get more help at https://help.gradle.org
Deprecated Gradle features were used in this build, making it incompatible with
Gradle 8.0.
You can use '--warning-mode all' to show the individual deprecation warnings
and determine if they come from your own scripts or plugins.
See
https://docs.gradle.org/7.5.1/userguide/command_line_interface.html#sec:command_line_warnings
Execution optimizations have been disabled for 1 invalid unit(s) of work during
this build to ensure correctness.
Please consult deprecation warnings for more details.
BUILD FAILED in 1h 2m 41s
232 actionable tasks: 153 executed, 67 from cache, 12 up-to-date
Publishing build scan...
https://ge.apache.org/s/724pdmz2qmuzs
Build step 'Invoke Gradle script' changed build result to FAILURE
Build step 'Invoke Gradle script' marked build as failure
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]